要做的需求很简单,就是一个axios的简单请求,如下:
axios({
method: 'post',
url: '/api/login',
data: {
username,
pwd
}})
但是问题来了,后端说取不到我的username和pwd,问题又来了,我确实传过去了,黑人问号脸???,然后我找了一下资料,终于把值成功传过去,后端也成功取到了。
原因:后端用的框架是 spring mvc ,并且在这个方法上使用了注解 @RequestParam,这个就只能从请求的地址中取出参数,也就是只能从 username=admin&pwd=11111 这种字符串中解析出参数,也就是编码格式(content-type)为:application/x-www-form-urlencode。(表单form的enctype属性的编码方式有两种:application/x-www-form-urlencode和multipart/form-data),但是axios会把请求的数据转换成json格式,即为:application/json;charset=UTF-8,所以格式不同,就取不值了。
解决方案我尝试了有6种,大家可以根据自己的需求选择:
1.用 URLSearchParams
let param = new URLSearchParams()param.append('username', &