express处理get请求和post请求

一、处理get请求

(1)req.query

1》定义:

此属性是一个对象,包含路由中每个查询字符串参数的属性。此对象默认为 {}

2》代码示例:

例如:获取http://127.0.0.1:8000/?name=jane 的name的值

javascript 复制代码
const express=require('express');
const app=express();
app.get('/',(req,res)=>{
    let name=req.query.name;
    res.send(`hello ${name}`);
    console.log('name的值为'+name);
})

(2)req.params

1》定义:

此属性是一个包含映射到命名路由"参数"的属性的对象。此对象默认为 {}

2》代码示例:

例如:获取http://127.0.0.1:8000/?name=jane 的name的值

javascript 复制代码
const express=require('express');
const app=express();
app.get('/user/:name',(req,res)=>{
    res.send('hello')
    console.log(req.params); //输出{ name: 'jane' }
})

二、处理post请求

(1)req.body

1》定义:

此属性包含在请求正文中提交的数据键值对。默认情况下,它是 undefined,并在你使用urlencoded、 body-parser 和 multer 等正文解析中间件时填充

Express框架4.16版本前不包含解析POST请求的API,需要安装第三方模块 body-parser 或 multer进行解析,这之后req.body默认为{ }。4.16版本后内置了urlencoded中间件可解析post请求数据,分别放置在req.body中。

(2)body-parser中间件

1》定义:

仅做了解,使用推荐内置中间件

body-parser是用来解析POST请求体的中间件,默认只能解析application/x-www-form-urlencoded和application/json类型的数据。不同的数据格式,需配置不同的解析器

Express 4.16.0 版本及之后,express.json() 和 express.urlencoded() 这两个中间件被直接集成进了 Express,成为了express内置中间件。所以在许多情况下,你不再需要额外安装 body-parser。不过,为了兼容旧版本的 Express 或者其他框架,了解 body-parser 的使用仍然是有帮助的。

2》安装:

npm install body-parser

3》使用:

(1)常见的form提交:application/x-www-form-urlencoded
javascript 复制代码
const bodyParser = require('body-parser');
app.use(bodyParser.urlencoded({extended:true}));

extended: true 选项允许解析复杂的 URL 编码数据,如嵌套对象和数组

(2)提交json格式的数据:application/json
javascript 复制代码
app.use(bodyParser.json());

(3)multer中间件

具体见:http://t.csdnimg.cn/5YPXJ

1》定义:

multer中间件一般用来解析multipart/form-data类型的数据(通常用于上传文件)

提交文件:multipart/form-data

eg:<input type=file enctype="multipart/form-data" name="filename">

2》安装:

npm install multer -save

3》导入:

const multer=require('multer');

(4)内置中间件

1》定义:

Express 4.16.0以上增加了一些内置的中间件,对于基本的json和urlencoded解析,可以不用body-parser

2》内置中间件

express.json()和express.urlencoded(({extended:true|false}))

3》使用:
(1)内置中间件express.json():解析application/json
javascript 复制代码
const express = require('express');
const app = express();
app.use(express.json());
app.post('/json', (req, res) => {
    console.log(req.body); // 这里的 req.body 会包含解析后的 JSON 数据
    res.send('JSON data received!');
  });
app.listen(3000, () => {
    console.log('Server is running on port 3000');
  });
(2)内置中间件express.urlencoded():解析application/x-www-form-urlencoded
javascript 复制代码
app.use(express.urlencoded({extended:true}))
app.post('/form', (req, res) => {
    console.log(req.body); // 这里的 req.body 会包含解析后的 URL 编码数据
    res.send('Form data received!');
  });
app.listen(3000, () => {
    console.log('Server is running on port 3000');
  });
相关推荐
垣宇14 小时前
Vite 和 Webpack 的区别和选择
前端·webpack·node.js
爱吃南瓜的北瓜14 小时前
npm install 卡在“sill idealTree buildDeps“
前端·npm·node.js
翻滚吧键盘15 小时前
npm使用了代理,但是代理软件已经关闭导致创建失败
前端·npm·node.js
hamburgerDaddy116 小时前
从零开始用react + tailwindcs + express + mongodb实现一个聊天程序(一)
express
浪九天16 小时前
node.js的版本管理
node.js
浪九天17 小时前
node.js的常用指令
node.js
jingwang-cs17 小时前
内外网隔离文件传输解决方案|系统与钉钉集成+等保合规,安全提升70%
安全·中间件·钉钉·安全架构
WeiLai111219 小时前
面试基础--微服务架构:如何拆分微服务、数据一致性、服务调用
java·分布式·后端·微服务·中间件·面试·架构
浪九天20 小时前
Vue 不同大版本与 Node.js 版本匹配的详细参数
前端·vue.js·node.js
小纯洁w1 天前
Webpack 的 require.context 和 Vite 的 import.meta.glob 的详细介绍和使用
前端·webpack·node.js