微信小程序request请求后台接收不到参数问题
一. 小程序部分代码二. 后端三. 问题代码四. 请求头一. 小程序部分代码
发一个普通的request请求
wx.request({url: app.globalData.server_prefix + '/api/v1.0/songlists/user/wxLogin/',method: 'POST', data: {code: that___.data.login_code,userHead: that___.data.userInfo.avatarUrl,userName: that___.data.userInfo.nickName,userGender: that___.data.userInfo.gender,userCity: that___.data.userInfo.country,userProvince: that___.data.userInfo.province},success: function(res) {console.log("request:", res)},fail: function(res) {console.log(res)}})},
二. 后端
请求过来后并无参数
三. 问题代码
发现request请求里面缺少请求头,填上如下请求头,后端还是没参数
header: {'content-type': 'application/json' // 默认值}
查阅资料后发现
有时参数为application/json的请求后台接收参数为空,改成application/x-www-form-urlencoded就好了
四. 请求头
常见的表单数据提交数据的编码类型content-type
application/x-www-form-urlencodedapplication/jsonmultipart/form-datatext/xml
大家都知道,HTTP 协议是以 ASCII 码传输,建立在 TCP/IP 协议之上的应用层规范。规范把 HTTP 请求分为三个部分:状态行、请求头、消息主体。
协议规定 POST 提交的数据必须放在消息主体(entity-body)中,但协议并没有规定数据必须使用什么编码方式。
服务端通常是根据请求头(headers)中的 Content-Type 字段来获知请求中的消息主体是用何种方式编码,再对主体进行解析。所以说到 POST 提交数据方案,包含了 Content-Type 和消息主体编码方式两部分。
当设置为请求头的Content-Type设为application/json时,不能直接发送json对象,需要把json对象序列化才行。
如果觉得《微信小程序request请求后台接收不到参数问题》对你有帮助,请点赞、收藏,并留下你的观点哦!