【Node.js从基础到高级运用】七、基本的网络编程

基本的网络编程

在这一节中,我们将介绍 Node.js 在网络编程方面的基础,特别是如何使用 Node.js 创建一个 HTTP 服务器。这是构建 Web 应用和服务的核心技能。

创建 HTTP 服务器

Node.js 的 http 模块提供了创建 HTTP 服务器和客户端的能力。以下是创建一个基本 HTTP 服务器的步骤:

步骤 1: 导入 http 模块

首先,在你的 Node.js 应用中导入 http 模块。

javascript 复制代码
const http = require('http');

步骤 2: 创建服务器

使用http.createServer()方法创建一个服务器。这个方法接受一个回调函数,该函数在每次收到请求时被调用。

javascript 复制代码
const server = http.createServer((req, res) => {
  res.writeHead(200, {'Content-Type': 'text/plain'});
  res.end('Hello, World!\n');
});

步骤 3: 监听端口

最后,使用服务器的 listen 方法监听一个端口。

javascript 复制代码
const port = 3000;
server.listen(port, () => {
  console.log(`Server running at http://localhost:${port}/`);
});

运行这个程序,你的 Node.js 应用现在应该可以通过在浏览器访问 http://localhost:3000/ 来响应简单的 Hello, World! 消息。

处理请求和发送响应

在上面的示例中,我们的服务器对所有请求都返回相同的响应。但在实际应用中,你可能需要根据不同的 URL 路径和请求方法来提供不同的响应。

你可以通过检查 req 对象的 urlmethod 属性来实现这一点。

javascript 复制代码
const http = require('http');

const server = http.createServer((req, res) => {
  const { url, method } = req;

  if (url === '/' && method === 'GET') {
    res.writeHead(200, {'Content-Type': 'text/html'});
    res.end('<h1>Welcome to the homepage!</h1>');
  } else if (url === '/about' && method === 'GET') {
    res.writeHead(200, {'Content-Type': 'text/html'});
    res.end('<h1>About Us</h1>');
  } else {
    res.writeHead(404, {'Content-Type': 'text/html'});
    res.end('<h1>404 Not Found</h1>');
  }
});

const port = 3000;
server.listen(port, () => {
  console.log(`Server running at http://localhost:${port}/`);
});

总结

通过这一节的学习,你已经掌握了如何使用 Node.js 创建一个基础的 HTTP 服务器,以及如何处理请求和发送响应。这为进一步学习构建完整的 Web 应用和服务打下了坚实的基础。

虽然使用原生的 Node.js http 模块就可以创建服务器,但在实际开发中,我们往往会借助于各种框架来简化开发。下一节,我们将介绍如何使用 Express------一个灵活且广泛使用的 Node.js Web 应用框架,来创建服务器和路由,处理更复杂的 Web 应用逻辑。

相关推荐
爱健身的小刘同学25 分钟前
Vue 3 + Leaflet 地图可视化
前端·javascript·vue.js
神秘的猪头38 分钟前
Ajax 数据请求:从零开始掌握异步通信
前端·javascript
黛色正浓1 小时前
leetCode-热题100-贪心合集(JavaScript)
javascript·算法·leetcode
稀饭521 小时前
用changeset来管理你的npm包版本
前端·npm
TeamDev1 小时前
基于 Angular UI 的 C# 桌面应用
前端·后端·angular.js
Komorebi゛1 小时前
【CSS】斜角流光样式
前端·css
Irene19911 小时前
CSS 废弃属性分类总结
前端·css
青莲8431 小时前
Android 事件分发机制 - 事件流向详解
android·前端·面试
musashi1 小时前
用 Electron 写了一个 macOS 版本的 wallpaper(附源码、下载地址)
前端·vue.js·electron
满天星辰1 小时前
Typescript之类型总结大全
前端·typescript