nodejs第三方模块 express框架 传参

nodejs第三方模块 express框架 传参

get接口

动态参数

以这个举例 http://localhost:8001/edit/124
其中,/124传递的id124就是动态参数
服务器通过req.params获取

app.get("/edit/:id",(req,res)=>{
    console.log(req.params)
    res.send("发送成功")
})

这个在我们删除和编辑数据的时候最常用,根据指定的id删除内容,以及编辑内容时的数据回显。

查询字符串参数

以这个举例:http://localhost:8001/index/?id=1&name=zs
其中,?id=18&name=zs就是查询字符串参数
服务器通过req.query获取

app.get("/index",(req,res)=>{
    console.log(req.query)
    res.send("发送成功")
})

get请求的参数是跟在地址栏中的,post是放在请求体中,这是和post请求方式不同的一点,所以安全性是没有post请求高的。

post接口

普通键值对参数

具体来说当content-typex-www-form-urlencoded时,表示上传的普通简单键值对
app.use(express.urlencoded()); 将请求体中携带的普通键值对参数 解析 放在reqbody属性当中

// 1. 使用中间件
app.use(express.urlencoded());  //将请求体中携带的普通键值对参数 解析 放在req的body属性当中

app.post("/add",function(req,res){
    //2. 可以通过req.body来获取post传递的键值对	
    res.json(req.body)

})

  1. app.use(....)之后,在res中就会多出一个属性res.body
  2. extended: false:表示使用系统模块querystring来处理传入的参数,也是官方推荐的
  3. extended: true:表示使用第三方模块qs来处理传入的参数.

json格式的参数

在post传递参数时,如果要传入的参数比较复杂(多级嵌套),则可以使用json格式上传。
具体来说当content-typeraw时,表示上传的json格式的参数

app.use(express.json());
// 会自动加入req.body属性,这个属性中就包含了post请求所传入的参数

// 用来处理JSON格式的数据
app.post('/postJSON',(req,res)=>{
    // 后端收到post传参
    console.log(req.body);
    
    res.send('/postJSON')
})

form-data文件上传

如果post涉及文件上传操作,则需要在服务器端额外使用第三方模块 例如multer这个包(不属于express)来获取上传的信息。

Multer是一个node.js 中间件,用于处理content-typemultipart/form-data类型的表单数据,它主要用于上传文件。

// 1. 引入包
const multer = require('multer');
// 2. 配置
const upload = multer({dest:'uploads/'}) // 上传的文件会保存在这个目录下
// uploads表示一个目录名,你也可以设置成其它的

// 3. 使用
// 这个路由使用第二个参数 .upload.single表示单文件上传, 'cover' 表示要上传的文件在本次上次数据中的键名。对应于前端页面上的:
//  <input type="file" name='cover'/>

app.post("/postfile",upload.single('cover'), function(req,res){
    // req.file 记录了文件上传的信息
    // req.body 记录了其它普通参数(非文件)的信息
	// 其它操作
})
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值