前端HTTP发POST请求携带参数与后端接口接收参数

前端HTTP请求携带参数与后端接口接收参数

HTTP的GET请求与POST请求

HTTP请求方式有GET、POST、PUT、DELETE等八种,最常见的就是GET、POST,下面说一下GET请求,很简单。

GET是按照规定参数只能写在URL里面(虽然可以有请求体但是不符合规定),没有请求体也就是data,那传就非常简单了,前端就是字符串拼接,后端如果是RESTful风格就占位符+@PathValue,传统方式就直接写就行了,当然参数就需要比较简单自定义对象当然是不行的,list参数也是非常不方便,GET请求就是做查询用,其他的不要用。其他的用什么,如果是RESTful风格规定的非常严的话是POST、PUT、DELETE换着用,但是规定不严的话POST搞定。

使用POST就可以把数据放到请求体data里面可以传复杂对象、list等,但是这就有麻烦了,这里直接说前后端分离的SpringBoot(用的是SpringMVC)项目(SSM项目也一样),复杂的是传过来的数据类型多样,这里的类型不是Integer、String这种,是Content—Type,有JSON型有表单性有文件型,那什么时候用什么样的方式,前端如何发请求,后端如何收参数,这里系统的总结一下,看下面。

常见HTTP内容类型Content-Type

  • application/json:JSON数据格式
  • multipart/form-data:需要在表单中进行文件上传时,就需要使用该格式
  • application/x-www-form-urlencoded:表单中默认的encType,表单数据被编码为key/value格式发送到服务器

后端收参方式-前端对应传参方式

废话不多说直接上代码

application/json

一个参数(基本数据类型的包装类型),

这里注意必须加@RequestBody不然接收不到

@PostMapping(value="methodName",consumes = "application/json")
public CommonResult methodName(@RequestBody Integer id)

前端对应传参方式(以axios传参为例,下同)

let id=1;
axios.post("url",id)

在这里插入图片描述

多个参数(基本数据类型的包装类型)

错误写法

@PostMapping(value="methodName",consumes = "application/json")
public CommonResult methodName(@RequestBody Integer id,Integer name);
//或
public CommonResult methodName(@RequestBody Integer id,@RequestBody Integer name);

@RequestBody只能加在一个参数前面。

正确方式

@PostMapping(value="methodName",consumes = "application/json")
public CommonResult methodName(@RequestBody HashMap<Sting,Object> s);
//或 user:{id,name}
public CommonResult methodName(@RequestBody User user);

前端传参方式,只写data部分了

{
   userId: 0,//"userId":0
   username: "string"//"username":"sdsa"
}
//或者
let user={}
user.id=1//let user={user:1}
data:user

就ok了

在这里插入图片描述

multipart/form-data

文件或表单,为什么要用这个呢,因为有一个超好用的东西FormData!

就上面的多个参数问题,后端就是不想封装怎么办

后端

@PostMapping(value="methodName",consumes = "multipart/form-data")
public CommonResult methodName(Integer id,Integer name);
//用formdata就别加@RequestBody了,@RequestBody是为json服务的

前端

	  let data=new FormData();
      data.append("id",1)
      data.append("name",2)//前面的key记得对应!
      this.$http({
        url: "http://localhost:8084/test/oneParam",
        method: "POST",
        data: data, 
        //headers: { 使用FormData可以不写这个,FormData会自动添加
        //  "Content-Type": "multipart/form-data",
        //},
})

multipart/form-data 主要还是传文件但是如果想省事用它传数据也挺好,如果后端参数是一个自定义对象

public CommonResult methodName(User user);

前端FormData就是key是user对象的属性,因为SpringMVC会帮我们把对象解析成一个个属性

在这里插入图片描述

但是主要一点!!!微信小程序里面 不支持new FormData !!!

application/x-www-form-urlencoded

使用这种方式发数据需要数据像真的表单一样,需要提交一个字符串比如

data: 'userId=1&name=dsadsa',

就和写在url里面一样,可以看出不好使,要想用最好使用qs库。

参考这篇: application/x-www-form-urlencoded方式post传值其实分两种一种json一种字符串。

不好用但是在小程序开发里面不得不用,上面说了小程序不支持new FormData,要发application/x-www-form-urlencoded形式的,要怎么发呢,比如后端需要一个user对象,那么

let user={};
user.id=1
wx.request({
    .....
    data:user
})

就这样,后端什么都不加。

总结

后端标明并限制content-type是@PostMapping(value=“methodName”,consumes = “multipart/form-data”),consumes,基本就这样,然后@RequestParam看这个:POST、GET、@RequestBody和@RequestParam区别,以后再出bug就不用满世界查了,简简单单。

然后说一下为哈两周没有发文章,虽然也没人看哈哈,做课设去了,没错,然后现在终于放暑假了,休息了两天,不能再放纵了,希望能在8.1号之前准备好面试题,因为字节提前批8.1号截止,后面就是正式批了。

预告接下来要发的文章:

mysql索引怎么存数据怎么存(不只是常见的内容哦,有一点我的探索)

做课设过程中的团队配合问题,过程管理yyds

参考

常见的Content-Type类型

application/x-www-form-urlencoded方式

POST、GET、@RequestBody和@RequestParam区别

https://www.cnblogs.com/ranyonsue/p/13674493.html

https://www.jianshu.com/p/451db33f33a1

  • 33
    点赞
  • 76
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
HTTP POST请求可以通过请求行和请求体来传递参数。对于前端,可以将参数拼接在请求体中,而后端可以使用不同的方式来接收参数。在RESTful风格中,可以使用占位符和@PathValue来接收参数。而在传统方式中,可以直接在代码中获取参数。需要注意的是,GET请求更适合用于查询操作,而POST请求更适合用于其他操作。在后端,可以通过标明并限制content-type为"multipart/form-data"来接收参数。此外,可以使用@RequestParam来获取参数。总之,HTTP POST请求可以灵活地传递参数,具体的方式取决于前后端的需求和约定。\[1\]\[2\]\[3\] #### 引用[.reference_title] - *1* [http post参数传递的两种方式](https://blog.csdn.net/qiuchangyong/article/details/106381074)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [前端HTTPPOST请求携带参数后端接口接收参数](https://blog.csdn.net/weixin_45855671/article/details/118639202)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值