node.js —— 解读http模块

目录

http模块:

http模块的引入:

创建web服务器的基本步骤:

web服务器的一些基本属性:

上述知识汇总案例:


http模块:

http模块的引入:

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

创建web服务器的基本步骤:

  • 导入 http 模块
  • 创建 web 服务器实例
  • 为服务器实例绑定 request 事件,监听客户端的请求
  • 启动服务器
1、引入http模块:
javascript 复制代码
const http = require('http')
2、创建web服务器实例:
javascript 复制代码
const server = http.createServer()
3、为服务器实例绑定 request 事件,监听客户端的请求:
javascript 复制代码
server.on('request', (req, res) => {
    console.log('Someone visited my web server')
})
4、启动服务器:
javascript 复制代码
server.listen(2386, () => {
    console.log('server running at 127.0.0.1:2386');
})

web服务器的一些基本属性:

req 请求对象:

只要服务器接收到了客户端的请求,就会调用通过 server.on() 为服务器绑定的 request 事件处理函数。 如果想在事件处理函数中,访问与客户端相关的数据或属性,可以使用如下的方式:

javascript 复制代码
server.on('request', (req, res) => {
    //req是请求对象,包含了与客户端的相应属性与数据
    //req.url是客户端请求的url地址
    //req.method是客户端请求的method请求类型
    console.log(`您请求的url地址是${req.url},您请求的方式是${req.method}`)
})
res 响应对象:

在服务器的 request 事件处理函数中,如果想访问与服务器相关的数据或属性,可以使用如下的方式:

javascript 复制代码
server.on('request', (req, res) => {
    // res是响应对象,他包含了服务器的数据与属性
    res.end(`您请求的url地址是${req.url},您请求的方式是${req.method}`)
})
解决中文乱码问题:

当调用 res.end() 方法,向客户端发送中文内容的时候,会出现乱码问题,此时,需要手动设置内容的编码格式:

javascript 复制代码
server.on('request', (req, res) => {
    //响应头,设置字符集为utf-8,防止网页出现乱码
    res.setHeader('Content-Type', 'text/html;charset=utf-8')
    // res.end()的作用是,向客户端发送指定的内容,并结束此次的请求处理
    res.end(`您请求的url地址是${req.url},您请求的方式是${req.method}`)
})

上述知识汇总案例:

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

const server = http.createServer()
//req是请求对象,包含了与客户端的相应属性与数据
//req.url是客户端请求的url地址
//req.method是客户端请求的method请求类型

// res是响应对象,他包含了服务器的数据与属性

server.on('request', (req, res) => {
    console.log('Someone visited my web server')
    console.log(`您请求的url地址是${req.url},您请求的方式是${req.method}`)
    console.log(req);

    //响应头,设置字符集为utf-8,防止网页出现乱码
    res.setHeader('Content-Type', 'text/html;charset=utf-8')

    // res.end()的作用是,向客户端发送指定的内容,并结束此次的请求处理
    res.end(`您请求的url地址是${req.url},您请求的方式是${req.method}`)
})

server.listen(2386, () => {
    console.log('server running at 127.0.0.1:2386');
})

根据不同的 url 响应不同的 html 内容:

  1. 获取请求的 url 地址
  2. 设置默认的响应内容为 404 Not found
  3. 判断用户请求的是否为 / 或 /index.html 首页
  4. 判断用户请求的是否为 /about.html 关于页面
  5. 设置 Content-Type 响应头,防止中文乱码
  6. 使用 res.end() 把内容响应给客户端
相关推荐
你真的可爱呀24 分钟前
3.MySQL 数据库集成
mysql·node.js·express
你真的可爱呀1 小时前
4.前后端联调(Vue3+Vite + Express + MySQL)
mysql·node.js·vue·express
weixin_462446232 小时前
【原创实践】Node.js 动态生成 SVG 项目规划纸模板 高仿 纸由我 PaperMe
node.js·生成纸张
PAQQ2 小时前
ubuntu22.04 搭建 Opencv & C++ 环境
前端·webpack·node.js
程序员爱钓鱼13 小时前
Node.js 编程实战:路由处理原理与实践
后端·node.js·trae
Lucky_Turtle13 小时前
【Node】npm install报错npm error Cannot read properties of null (reading ‘matches‘)
前端·npm·node.js
聊天QQ:2769988517 小时前
基于线性自抗扰(LADRC)的无人船航向控制系统Simulink/Matlab仿真工程探索
node.js
不会写DN1 天前
JavaScript call、apply、bind 方法解析
开发语言·前端·javascript·node.js
Tiam-20161 天前
安装NVM管理多版本node
vue.js·前端框架·node.js·html·es6·angular.js
fengGer的bugs1 天前
从零到一全栈开发 | 跑腿服务系统:小程序+Vue3+Node.js
小程序·node.js·全栈开发·跑腿服务系统