【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 应用逻辑。

相关推荐
李白的天不白1 小时前
SSR服务端渲染
前端
XinZong1 小时前
OpenClaw 实现「龙虾」vs 龙虾 vs 用户 ws对话实现方案 + 实际落地项目
javascript
卷帘依旧2 小时前
WebSocket 比 SSE 复杂在哪里
javascript
卷帘依旧2 小时前
SSE(Server-Sent Events)完全指南
前端
码云之上2 小时前
万星入坞:我们如何用三层插件体系干掉巨石应用
前端·架构·前端框架
kyriewen2 小时前
一口气讲清楚 Monorepo、Turborepo、pnpm、Changesets 到底是什么?
前端·架构·前端工程化
logo_282 小时前
Xpath语法规则的学习和使用
javascript·python·xpath·xpath语法
IT_陈寒3 小时前
React性能优化踩的坑,这个错你可能也会犯
前端·人工智能·后端
zhangxingchao3 小时前
AI应用开发三:RAG技术与应用
前端·人工智能·后端
摘星小杨3 小时前
如何在前端循环调取接口,实时查询数据
开发语言·前端·javascript