使用express框架写接口,三种不同类型数据接收 (普通键值对、复杂类型JSON、文件上传)

一、三种情况
在这里插入图片描述
二、代码

//引入模块
const express = require('express');
//调用express方法
const app = express();
//1.post接口-普通键值对参数
//  使用中间件
//具体来说当content-type为x-www-form-urlencoded时,表示上传的普通简单键值对 。
app.use(express.urlencoded());//用express.urlencoded()来获取请求体的参数。
//创建服务
app.post("/add",function(req,res){
    // 可以通过req.body来获取post传递的键值对	
    res.json(req.body)
})
//2.post接口-json格式的参数
app.use(express.json());
// 会自动加入req.body属性,这个属性中就包含了post请求所传入的参数

// 用来处理JSON格式的数据
app.post('/postJSON',(req,res)=>{
    // 后端收到post传参
    console.log(req.body);
      res.send('/postJSON')
})
//3.post接口-form-data文件上传
//首先安装multer包 npm i multer
//使用
// 3.1. 引入包
const multer = require('multer');
// 3.2. 配置
const upload = multer({dest:'uploads/'}) // 上传的文件会保存在这个目录下
// uploads表示一个目录名,你也可以设置成其它的

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

app.post("/postfile", upload.single('cover'), function(req,res){
    // req.file 记录了文件上传的信息
    // req.body 记录了其它普通参数(非文件)的信息
	// 其它操作
})
//监听服务
app.listen('8088', () => {
  console.log('8088');
});


三、效果
使用postmen软件测试
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值