第一步:导入http模块
const http = require("http")
第二步:创建web服务器实例
调用http.createServer()方法创建web服务器实例
const server = http.createServer()
第三步:为服务器实例绑定request事件,监听客户端的请求
只要有客户端请求我们的服务器,就会触发request事件,从而调用这个事件处理函数
req是请求对象,它包含了与客户端相关得数据和属性
req.url 是客户端请求得URL地址
req.method 是客户端的请求类型
res是响应对象,它包含了与服务器相关的数据和属性
res.end() :向客户端发送指定的内容,并结束这次请求的处理过程
server.on("request",(req,res) => {
// req是请求对象,它包含了与客户端相关得数据和属性
// req.url 是客户端请求得URL地址
// req.method 是客户端的请求类型
// res是响应对象,它包含了与服务器相关的数据和属性
// res.end() :向客户端发送指定的内容,并结束这次请求的处理过程
})
注意:当调用res.end()方法向客户端发送中文内容的时候会出现乱码问题,此时需要手动设置内容的编码格式
server.on("request",(req,res) => {
// req是请求对象,它包含了与客户端相关得数据和属性
// req.url 是客户端请求得URL地址
// req.method 是客户端的请求类型
// res是响应对象,它包含了与服务器相关的数据和属性
// res.end() :向客户端发送指定的内容,并结束这次请求的处理过程
// 为防止中文乱码的问题,需要设置响应头 Content-Type 对应的值为 text/html; charset=utf-8
res.setHeader('Content-Type', 'text/html; charset=utf-8')
// 响应给客户端的内容
res.end('响应给客户端的内容')
})
第四步:根据不同的url响应不同的内容
server.on("request",(req,res) => {
// 获取请求的url地址
const url = req.url
// 设置默认的内容 404
let content = "404 Not Found"
// 更具不同的url地址响应不同的内容
if(url === '/' || url === '/index.html') {
content = "首页"
} else if(url === '/test.html') {
content = "测试页面"
}
// 为防止中文乱码的问题,需要设置响应头 Content-Type 对应的值为 text/html; charset=utf-8
res.setHeader('Content-Type', 'text/html; charset=utf-8')
// 响应给客户端的内容
res.end(content)
})
第五步:启动服务器
调用server.listen(端口号,回调函数)方法启动服务器,
server.listen(80,() => {
// http://127.0.0.1:80,80端口可省略
console.log("http server running http://127.0.0.1")
})
完整代码
// 导入http模块
const http = require('http')
// 创建web服务器实例
const server = http.createServer()
// 为服务器实例绑定事件,监听客户端的请求
server.on('request', (req,res) => {
// 获取请求的url地址
const url = req.url
// 设置默认的内容 404
let content = "404 Not Found"
// 更具不同的url地址响应不同的内容
if(url === '/' || url === '/index.html') {
content = "首页"
} else if(url === '/test.html') {
content = "测试页面"
}
// 为防止中文乱码的问题,需要设置响应头 Content-Type 对应的值为 text/html; charset=utf-8
res.setHeader('Content-Type', 'text/html; charset=utf-8')
// 响应给客户端的内容
res.end(content)
})
// 启动服务器
server.listen(80,() => {
// http://127.0.0.1:80,80端口可省略
console.log("http server running http://127.0.0.1")
})