Nodejs-1.1 nodejs-http模块

本文讲解了Node.js中的http模块,如何创建基本web服务器,处理req和res对象,解决中文乱码,以及动态响应不同URL的示例。涵盖了HTTP服务器的创建、事件处理和常见问题解决。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1 什么是http模块

http模块是Node.js官方提供的,用来创建web服务器的模块。通过http模块提供的==http.createServer()==方法,就能方便的把一台普通的电脑编程一台Web服务器,从而对外提供Web资源服务。

2 创建最基本的web服务器

  1. 导入http模块
    const http=require('http')
  2. 调用==http.createServer()==方法,即可快速创建一个web服务器实例
    const server = http.createServer()
  3. 为服务器实例绑定request事件,即可监听客户端发送过来的网络请求
// 使用服务器实例的 .on方法,为服务器绑定一个request事件
server.on('request', (req, res) => {
    // 只要有客户端来请求我们的服务器,就会触发request事件,从而调用这个事件处理函数
    console.log('Someone visit our web server.');
})

  1. 启动服务器
// 调用server.listen(端口号,cb回调)方法,即可启动web服务器
server.listen(80, () => {
    console.log('http server running at http:');
})

3 req请求对象

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

server.on('request', function (req, res) {
    // 只要有客户端来请求我们的服务器,就会触发request事件,从而调用这个事件处理函数
    // req是请求对象,他包含了与客户端相关的数据和和属性,例如
    // req.url 是客户端请求的URL地址
    // req.method是客户端的method请求类型
    const str = `Your request url is${req.url},and request method is${req.method}`
    console.log(str);
})

4 req响应对象

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

server.on('request', function (req, res) {
    // res 是响应对象,他包含了与服务器相馆的数据和属性
    // 要发送到客户端的字符串
    const str = `Your request url is${req.url},and request method is${req.method}`
    // res.end()方法的作用
    // 向客户端发送指定的内容,并结束这次请求的处理过程
    res.end(str)
})

解决中文乱码问题

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

server.on('request', function (req, res) {
    // 发送的内容包含中文
    const str = `你请求的url地址是${req.url},请求的method类型是${req.method}`
    // 为了防止中文显示乱码的问题,需要设置响应头Content-Type的值为text/html; charset=utf-8
    res.setHeader('Content-Type', 'text/html; charset=utf-8')
    // 把包含中文的内容响应给客户端
    res.end(str)
})

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

1.核心实现步骤

  1. 获取请求的url地址
  2. 设置默认的响应内容为404 Not found
  3. 判断用户请求的是否为==/index.html==首页
  4. 判断用户请求的是否为==/about.html==关于页面
  5. 设置Content-Type响应头防止中文乱码
  6. 使用==res.end()==把内容响应给客户端

动态响应内容

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

像我这样的人112

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值