Node.js——http 模块(二)

devtools/2025/1/14 17:07:37/
http://www.w3.org/2000/svg" style="display: none;">

个人简介

👀个人主页: 前端杂货铺
🙋‍♂️学习方向: 主攻前端方向,正逐渐往全干发展
📃个人状态: 研发工程师,现效力于中国工业软件事业
🚀人生格言: 积跬步至千里,积小流成江海
🥇推荐学习:🍍前端面试宝典 🎨100个小功能 🍉Vue2 🍋Vue3 🍓Vue2/3项目实战 🥝Node.js实战 🍒Three.js

🌕个人推广:每篇文章最下方都有加入方式,旨在交流学习&资源分享,快加入进来吧

内容参考链接
Node.js(一)Node.js——fs(文件系统)模块
Node.js(二)Node.js——path(路径操作)模块
Node.js(三)Node.js——http 模块(一)

文章目录

    • 前言
    • 设置 HTTP 响应报文
    • Simple Demo
    • 总结

前言

上篇文章我们学习了 path 模块,本篇文章我们学习 Node.js 的 http 模块。

http 模块是核心模块,它提供了 HTTP 服务器和客户端功能,主要用于前后端通信。


设置 HTTP 响应报文

下面,我们学习如何进行 HTTP 响应报文的设置,其实也很简单,只需要 response.xxx 调一些属性和方法即可。

  • statusCode: 设置响应状态码
  • statusMessage: 设置响应状态的描述
  • setHeader(): 设置响应头
  • write(): 设置响应体
const http = require('http');// 创建服务对象
const server = http.createServer((request, response) => {// 设置响应状态码response.statusCode = 201;// 设置响应状态的描述response.statusMessage = 'hi';// 设置响应头response.setHeader('content-type', 'text/html;charset=utf-8');response.setHeader('Server', 'Node.js');response.setHeader('DIYHeader', 'diy header');response.setHeader('test', ['a', 'b', 'c']);// 设置响应体response.write('Hello, ');response.write('This ');response.write('is ');response.write('zahuopu');response.end('!');
})// 监听端口,启动服务
server.listen('9000', () => {console.log('服务启动成功...')
})

https://i-blog.csdnimg.cn/direct/3ebc4965352e442d8f4d8d421e4ef137.png" alt="在这里插入图片描述" />


Simple Demo

下面我们编写一个小 Demo,实现响应页面信息(包括 html、css 和 js),设置 MIME 类型 并进行错误处理。

const http = require('http');
const fs = require('fs');
const path = require('path');// MIME类型(Multipurpose Internet Mail Extensions)是一种标准,用于表示文档、文件或字节流的性质和格式‌‌。
// 设置HTTP响应的 Content-Type 头部,以告诉浏览器如何处理返回的内容。
const mimes = {html: 'text/html',css: 'text/css',js: 'text/javascript',png: 'image/png',jpg: 'image/jpeg',gif: 'image/gif',mp4: 'video/mp4',mp3: 'audio/mpeg',json: 'application/json',
}const server = http.createServer((request, response) => {// 获取请求路径const { pathname } = new URL(request.url, 'http://127.0.0.1');// 拼接完整的文件路径const filePath = __dirname + pathname;fs.readFile(filePath, (err, data) => {// 处理错误信息if (err) {response.setHeader('content-text', 'text/html;charset=utf-8');switch (err.code) {// 未找到case 'ENOENT':response.statusCode = 404;response.end('<h1>404 Not Found</h1>');// 无权限case 'EPERM':response.statusCode = 403;response.end('<h1>403 Forbidden</h1>');// 其他错误default:response.statusCode = 500;response.end('<h1>Internal Server Error</h1>');}return;}// 获取文件后缀名const ext = path.extname(filePath).slice(1);// 获取对应的类型const type = mimes[ext];if (type) {if (ext === 'html') {response.setHeader('content-text', type + ';charset=utf-8');}} else {response.setHeader('content-type', 'application/octet-stream');}// 响应文件内容response.end(data);})
})server.listen('9000', () => {console.log('服务已启动...');
})

index.html 文件中编写如下内容:

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><title>Document</title><link rel="stylesheet" href="./index.css" /></head><body><h2>前端杂货铺</h2><script src="./index.js"></script></body>
</html>

index.css 文件中编写如下内容:

h2 {color: orange;
}

index.js 文件中编写如下内容:

const h2 = document.querySelector('h2');
h2.style.fontSize = 20 + 'px';
h2.style.fontWeight = 200;

启动服务后,访问 9000 端口

https://i-blog.csdnimg.cn/direct/27e57aaa763d46319d174e28282dc544.png" alt="在这里插入图片描述" />

https://i-blog.csdnimg.cn/direct/2ea4c1c043b24f4d9f7bdf57f738df90.png" alt="在这里插入图片描述" />

https://i-blog.csdnimg.cn/direct/8efb2989c1224d9199ddff91d8caf4ea.png" alt="在这里插入图片描述" />

https://i-blog.csdnimg.cn/direct/04b30e44005d4b148f4e228523359c13.png" alt="在这里插入图片描述" />


总结

本篇文章我们首先学习了 HTTP 响应报文,包括设置响应状态码、设置响应状态的描述、设置响应头和响应体等;此外,我们还编写了一个 Demo,学习如何响应页面信息、认识了 MIME 并学会了如何进行错误处理等。

好啦,本篇文章到这里就要和大家说再见啦,祝你这篇文章阅读愉快,你下篇文章的阅读愉快留着我下篇文章再祝!


参考资料:

  1. Node.js教程(菜鸟教程)
  2. Node.js零基础视频教程(尚硅谷 · 李强)

https://i-blog.csdnimg.cn/blog_migrate/3cf97cbd47fc0cd482bf8e677dab493e.png" alt="在这里插入图片描述" />



http://www.ppmy.cn/devtools/150459.html

相关文章

Ubuntu Server挂载AWS S3成一个本地文件夹

2023年&#xff0c;AWS出了个mountpoint的工具&#xff1a; https://github.com/awslabs/mountpoint-s3 如下是另外一种方式&#xff0c;通过s3fs-fuse 这个工具 sudo apt-get install automake autotools-dev \fuse g git libcurl4-gnutls-dev libfuse-dev \libssl-dev libx…

Vue 开发者的 React 实战指南:性能优化篇

作为 Vue 开发者&#xff0c;在迁移到 React 开发时&#xff0c;性能优化的思路和方法会有所不同。本文将从 Vue 开发者熟悉的角度出发&#xff0c;详细介绍 React 中的性能优化策略。 渲染优化对比 Vue 的响应式系统 Vue 通过响应式系统自动追踪依赖&#xff0c;只有在数据…

Java(五十)java-IO流-缓冲流(BufferedInputStream和BufferedOutputStream)

接下来我们学习一下java缓冲流中的读取和写入类BufferedInputStream&#xff08;缓冲字节输入流&#xff09;和BufferedOutputStream&#xff08;缓冲字节输出流&#xff09;类&#xff0c;这个两个类的使用方法和IO流中的FileOutputStream和FileInputStream类是差不多的。但是…

hive3后创建表默认是外部表问题

hive3 hive4创建的表总是外部表&#xff0c;但是操作使用和内部表一样&#xff0c;修改成为默认是内部表 <property><name>metastore.metadata.transformer.class</name><value> </value> </property>注意空格是必须的 后面执行 desc fo…

从epoll事件的视角探讨TCP:三次握手、四次挥手、应用层与传输层之间的联系

目录 一、应用层与TCP之间的联系 二、 当通信双方中的一方如客户端主动断开连接时&#xff0c;仅是在客户端的视角下连接已经断开&#xff0c;在服务端的眼中&#xff0c;连接依然存在&#xff0c;为什么&#xff1f;——触发EPOLLRDHUP事件&#xff1a;对端关闭连接或停止写…

LabVIEW驱动电机实现样品自动搜索

利用LabVIEW控制电机驱动相机在XY平面上进行扫描&#xff0c;以检测样品位置。样品最初可能位于相机视野范围之外&#xff0c;需要实现自动搜索样品位置并完成精确定位扫描的功能。该系统需具有以下特点&#xff1a; 高效搜索&#xff1a;能够快速确定样品位置&#xff0c;缩短…

电脑之故障检测(Computer Fault Detection)

电脑之故障检测 在日常使用电脑的过程中&#xff0c;我们难免会遇到各种各样的故障。从简单的软件冲突到复杂的硬件损坏&#xff0c;这些问题往往让人头疼不已。然而&#xff0c;掌握一些基本的电脑故障检测方法&#xff0c;可以帮助我们快速定位问题所在&#xff0c;并采取相…

CHAIN OF RESPONSIBILITY(职责链)—对象行为型模式

1. 意图 使多个对象都有机会处理请求&#xff0c;从而避免请求的发送者和接收者之间的耦合关系。将这些对象连成一条链&#xff0c;并沿着这条链传递该请求&#xff0c;直到有一个对象处理它为止。 2. 动机 考虑一个图形用户界面中的上下文有关的帮助机制。用户在界面的任一部分…