javascript – 使用axios在POST multipart / form-data请求中发送文件和json
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了javascript – 使用axios在POST multipart / form-data请求中发送文件和json,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1103字,纯文字阅读大概需要2分钟。
内容图文
我试图将相同的多部分POST请求中的文件和一些json发送到我的REST端点.该请求直接来自使用axios库的javascript,如下面的方法所示.
doAjaxPost() {
var formData = new FormData();
var file = document.querySelector('#file');
formData.append("file", file.files[0]);
formData.append("document", documentJson);
axios({
method: 'post',
url: 'http://192.168.1.69:8080/api/files',
data: formData,
})
.then(function (response) {
console.log(response);
})
.catch(function (response) {
console.log(response);
});
}
但是,问题是当我在网络选项卡中的chrome开发人员工具中检查请求时,我找不到文档的Content-Type字段,而对于文件字段,Content-Type是application / pdf(我正在发送pdf文件).
在服务器上,文档的Content-Type是text / plain; charset = us-ascii.
更新:
我设法通过Postman发送一个正确的请求,将文件作为.json文件发送.虽然我发现这只适用于Linux / Mac.
解决方法:
要设置内容类型,您需要传递类文件对象.您可以使用Blob创建一个.
const obj = {
hello: "world"
};
const json = JSON.stringify(obj);
const blob = new Blob([json], {
type: 'application/json'
});
const data = new FormData();
data.append("document", blob);
axios({
method: 'post',
url: '/sample',
data: data,
})
内容总结
以上是互联网集市为您收集整理的javascript – 使用axios在POST multipart / form-data请求中发送文件和json全部内容,希望文章能够帮你解决javascript – 使用axios在POST multipart / form-data请求中发送文件和json所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。