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‘)})
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‘)})
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‘)})
安包: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(‘启动成功!‘)})