axios post怎么使用?传大量数据时,出现413 FULL head
使用axios发布文章,代码如下:
this.$axios({
method: 'post',
url: '/post',
data: {
description: opt.editorContent,
time: time,
...
},
})
.then(res => {
...
}
发送的请求是json格式的,后台常规方式无法获取,而且当description数据过大会报413 FULL head错误
手动改Content-Type
也不起作用
axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded';
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
更新:
刚刚在sf看到一个终极解决方案
==================
这个问题卡了一天了,百度谷歌都搜了一圈了,issue里也有一些信息(都使用了
qs.stringify
),但都使用了别名方式:记录下解决方法:
按道理,使用post方式,应该使用
['Content-Type'] = 'application/x-www-form-urlencoded'
方式才对。。。为什么还是json类型的。之前post一直是用
params
参数传递,导致和get请求一样,变成了URL parameters
跟在url里,导致了url太长,413 FULL head
报错了我喜欢使用配置的方式写axios,此时post需要在
transformRequest
里处理了,才能识别为x-www-form-urlencoded
类型哈哈,这个我刚用axios时也遇到过,jq的ajax是默认 application/x-www-form-urlencoded 的,也就是已经加密过的,但是 axios 不是。
感谢分享,学习了,倒是一直没遇到过这个问题