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

相关推荐
小桥风满袖9 分钟前
极简三分钟ES6 - ES9中for await of
前端·javascript
半花25 分钟前
i18n国际语言化配置
前端
编程贝多芬28 分钟前
Promise 的场景和最佳实践
前端·javascript
Asort30 分钟前
JavaScript 从零开始(四):基础语法详解——从变量声明到数据类型的完全指南
前端·javascript
木木jio32 分钟前
前端大文件分片上传 —— 基于 React 的工程化实现
前端·javascript
南雨北斗35 分钟前
JS的对象属性存储器
前端
Lotzinfly36 分钟前
12个TypeScript奇淫技巧你需要掌握😏😏😏
前端·javascript·面试
一个大苹果37 分钟前
setTimeout延迟超过2^31立即执行?揭秘JavaScript定时器的隐藏边界
javascript
开源之眼41 分钟前
React中,useState和useReducer有什么区别
前端
普郎特1 小时前
"不再迷惑!用'血缘关系'彻底搞懂JavaScript原型链机制"
前端·javascript