站三界导航
首页 uniapp代码uniapp:request 请求出现400错误问题

uniapp:request 请求出现400错误问题

  • uniapp代码
  • 来源:站三界导航
  • 185阅读
  • 2023-03-17

uniapp:request 请求出现400错误

开发需求:我们团队在使用 uniapp springboot 开发微信小程序项目,前端向后端发送request 请求时,前端爆出400错误。

400错误: 请求无效 (Bad request);出现这个请求无效报错说明请求没有进入到后端服务里

原因:
前端提交的数据或请求的Url,在后端参数中不能封装或不能处理;前端 uniapp中的uni.request请求中的header 需要编写正确,不然后端拿不到前台的数据,会爆400错误。

解决:
需要注意因为发送的是POST请求,所以需要将请求头设置为 ‘content-type’ : ‘application/x-www-form-urlencoded’ 并将method设置为PSOT类型。

uni.request请求中的header需要编写为:

header: {
        "Content-Type": "application/x-www-form-urlencoded"
    }

这里header的书写涉及data 数据说明

我们根据最终发送给服务器的数据是否为 String 类型,进行转换,如果传入的 data 不是 String 类型,会被转换成 String。

转换规则如下:

  • 对于 GET 方法,会将数据转换为 query string。例如 { name: 'name', age: 18 } 转换后的结果是 name=name&age=18
  • 对于 POST 方法且 header['content-type']application/json 的数据,会进行 JSON 序列化。
  • 对于 POST 方法且 header['content-type']application/x-www-form-urlencoded 的数据,会将数据转换为 query string。

案例:

uni.request({ url: 'https://www.xxx.com/request', //仅为示例,并非真实接口地址。 data: { text: 'uni.request' }, header: { "Content-Type": "application/x-www-form-urlencoded" }, // header: {},设置请求的 header 默认是application/json success: (res) => { console.log(res.data); this.text = 'request success'; } }); 
本文结束
本文来自投稿,不代表站三界导航立场,如若转载,请注明出处:https://www.zhansanjie.com/article/details/40297.html

版权声明:

1、本文系转载,版权归原作者所有,旨在传递信息,不代表看本站的观点和立场。

2、本站仅提供信息发布平台,不承担相关法律责任。

3、若侵犯您的版权或隐私,请联系本站管理员删除。

4、本文由会员转载自互联网,如果您是文章原创作者,请联系本站注明您的版权信息。

分享
站三界导航
本站声明:本站严格遵守国家相关法律规定,非正规网站一概不予收录。本站所有资料取之于互联网,任何公司或个人参考使用本资料请自辨真伪、后果自负,站三界导航不承担任何责任。在此特别感谢您对站三界导航的支持与厚爱。