nodejs处理http请求
一、Request(req)、Response(res)
data:image/s3,"s3://crabby-images/94ca2/94ca2ba20ee83110f814ef6bb6e71e5c7f169bf4" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/181ff/181ff16998fee65ad4c5f3c91191b105838dd95c" alt="在这里插入图片描述"
const http = require('http')
// req Request,res Response
const server = http.createServer((req, res) => {
// console.log('已经收到 http 请求')
const url = req.url // http://localhost:3000/index.html
console.log('url is: ', url) // /index.html
res.end('hello world') // res 返回信息给前端
})
server.listen(3000) // 可以监听 http 请求
console.log('http 请求已经被监听,3000 端口, 请访问 http://localhost:3000')
二、定义路由
data:image/s3,"s3://crabby-images/448f0/448f0e8219c0db224f00e08b573f691a1b7f2fe2" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/0a7d6/0a7d68900c291cf721f021b3cbd459cf25965c33" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/8d439/8d439e8ce709b687f0e6c6034cf489cd69d68192" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/3ce4e/3ce4e1a0690c3cd05ae55ef06dad65ebcb8b78d1" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/5b3b1/5b3b10b1699b53fb81b4cf0069acba747370d6d4" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/2356e/2356eb3da36488b7406d17bc9d3728b5c2f9cdbe" alt="在这里插入图片描述"
三、querystring
data:image/s3,"s3://crabby-images/c91c5/c91c57ce9c34c29e897bfa22a6aa784bc6c3e6d3" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/fb36c/fb36c4967c1ee25acf62617ddd7035d420bdf3a0" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/12258/1225880c019c409e028782ff665c410c3f660e41" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/9cb41/9cb41b93f6f27ea15ff96f8afceecc488a0a2134" alt="在这里插入图片描述"
const http = require('http')
const querystring = require('querystring')
// req Request,res Response
const server = http.createServer((req, res) => {
const url = req.url // favicon.ico
const path = url.split('?')[0] // /api/list
const queryStr = url.split('?')[1] // 'a=100&b=200' 非结构化
const method = req.method
// console.log('url is: ', url) // /api/list?a=100&b=200
// console.log('method is: ', method)
// 解析 querystring
// const query = {}
// queryStr && queryStr.split('&').forEach(item => {
// // item 即 a=100 形式
// const key = item.split('=')[0] // 'a'
// const val = item.split('=')[1] // '100'
// query[key] = val // { a: '100', b: '200' } 结构化
// })
const query = querystring.parse(queryStr)
console.log('query is ', query)
// 定义路由:模拟获取留言板列表
if (path === '/api/list' && method === 'GET') {
if (query.filterType === '1') {
res.end('this is list router, all')
}
if (query.filterType === '2') {
res.end('this is list router, only mine')
}
// res.end('this is list router') // res 的返回,后面会讲
}
// 定义路由:模拟创建留言
if (path === '/api/create' && method === 'POST') {
res.end('this is create router')
}
res.end('404')
})
server.listen(3000) // 可以监听 http 请求
console.log('http 请求已经被监听,3000 端口, 请访问 http://localhost:3000')
data:image/s3,"s3://crabby-images/fd6b1/fd6b13c5af39f0a6193c9c19b314361b1e35cd36" alt="在这里插入图片描述"
四、res返回数据
data:image/s3,"s3://crabby-images/0bc6d/0bc6d800f1e769e9b4b11a7047878a9e7079fb55" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/166aa/166aa9c7db8d117cde11d6310227ee00751740ce" alt="在这里插入图片描述"
五、获取req body
data:image/s3,"s3://crabby-images/a913e/a913e6c122328f55b7a42c3de13989ac10fad98e" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/3fb63/3fb63aeb8dc953941ce55597a46e2427a17fcfb3" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/72ee2/72ee2d72486be9b345e816f45a2feaa1c1878d1f" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/1e1d8/1e1d8de20424f3bd531aac20045975168c400b51" alt="在这里插入图片描述"
const http = require('http')
const querystring = require('querystring')
// req Request,res Response
const server = http.createServer((req, res) => {
const url = req.url
const path = url.split('?')[0]
const queryStr = url.split('?')[1]
const method = req.method
const query = querystring.parse(queryStr)
// 定义路由:模拟获取留言板列表
if (path === '/api/list' && method === 'GET') {
// res.end('this is list router')
// 返回结果
const result = {
errno: 0,
data: [
{ user: '张三', content: '留言1' },
{ user: '李四', content: '留言2' }
]
}
res.writeHead(200, { 'Content-type': 'application/json' })
res.end( JSON.stringify(result) ) // body
}
// 定义路由:模拟创建留言
if (path === '/api/create' && method === 'POST') {
// res.end('this is create router')
const reqType = req.headers['content-type']
let bodyStr = ''
req.on('data', chunk => { // 服务端怎么去识别“流”,并接收数据
// chunk 即“流”的每一段数据
bodyStr = bodyStr + chunk.toString()
})
req.on('end', () => { // 服务端怎么知道流完了
if (reqType === 'application/json') { // json 格式
const body = JSON.parse(bodyStr)
console.log('body is ', body) // 对象格式
}
res.end('接收完成') // 异步
})
// const result = {
// errno: 0,
// message: '创建成功'
// }
// res.writeHead(200, { 'Content-type': 'application/json' })
// res.end( JSON.stringify(result) ) // body
return
}
// 没有命中路由,默认 404
// res.end('404')
// res.writeHead(404, { 'Content-type': 'text/plain' })
// res.end('404 Not Found')
res.writeHead(404, { 'Content-type': 'text/html' })
res.end(`
<!DOCTYPE html>
<html>
<head>
<title>404</title>
</head>
<body>
<h1>404 Not Found</h1>
</body>
</html>
`)
})
server.listen(3000) // 可以监听 http 请求
console.log('http 请求已经被监听,3000 端口, 请访问 http://localhost:3000')
|