http
const http = require('http')
// 创建服务器
const server = http.createServer()
// 绑定事件,监听客户端的请求
server.on('request', (req, res) => {
// 写入响应头,防止中文乱码
res.writeHeader(200, {
'Content-Type': 'text/html; charset=utf-8'
})
res.end('你好 http 服务器!')
})
server.listen(3333, () => {
console.log('http server running at http://127.0.0.1:3333')
})
express
const express = require('express')
// 创建服务器
const app = express()
// 监听客户端的请求
// 只有客户端的请求类型是 get,并且 请求地址是 / 根路径的时候,
// 才会调用 后面指定的处理函数
app.get('/', (req, res) => {
// express 中,封装了更好用的 res.send 方法
res.send('你好,express 服务器!')
})
// 监听客户端的post请求,并且请求的地址是 /adduser 的时候,
// 才会调用后面指定的处理函数
app.post('/adduser', (req, res) => {
res.send('服务器处理成功!')
})
// 启动服务器
app.listen(4444, () => {
console.log('express server running at http://127.0.0.1:4444')
})
在express框架中获取客户端提交的表单数据
const express = require('express')
const qs = require('querystring')
const app = express()
// 监听客户端的 post 请求,且请求地址为 /adduser 的时候,会调用指定的处理函数
app.post('/adduser', (req, res) => {
// 注意:客户端提交到服务器的数据,都保存到了 req 请求对象中
// 只要客户端向服务器通过post方式,提交了表单,那么 就会触发 req 的 data 事件
// 只要安装一个 第三方的npm包,名字叫做 body-parser, 并进行简单配置,就能够直接使用 req.body获取到表单数据了
let str = ''
req.on('data', chunk => {
// 把每次得到的分片数据,拼接到 str 字符串中
// 如果 字符串 和 Buffer 数据进行拼接,得到结果,是字符串
str += chunk
// 思考:只要触发了 data,就证明有数据发送到服务器了,但是,什么时候,就证明数据已经发送和接收完毕了呢???
})
// 通过监听 req 的 end 事件,就能够直到数据已经发送完毕了,服务器也已经接收到了完整的数据!
req.on('end', () => {
// console.log(str)
// 对数据进行 URL 解码操作
// const strDecode = decodeURI(str)
// console.log(strDecode)
const result = qs.parse(str)
// 使用 express 的 send 方法,向客户端发送 对象
res.send(result)
})
// res.send('添加用户成功!')
})
app.listen(4444, () => {
console.log('express server running at http://127.0.0.1:4444')
})
使用body-parser包解析表单数据
安包:npm install body-parser -S
const express = require('express')
// 1. 导入 解析表单数据的包
const bodyParser = require('body-parser')
const app = express()
// 2. 配置一下
app.use(bodyParser.urlencoded({ extended: false }))
app.post('/adduser', (req, res) => {
console.log(req.body)
res.send('ok')
})
app.listen(4444, () => {
console.log('启动成功!')
})