当前后端分离的时候,有时候需要通过接口上传图片 ajax中提交的只能是文字性的内容,图片不能上传。
这里要用到formData , 关于fromData的介绍自己搜索,这里就不介绍了。
let formData = new FormData;
//formData.append('filedata',$("#fileUpload").prop('files')[0]);
formData.append('filedata',$("#fileUpload")[0].files[0]);
formData.append('user_id',1);
formData.append('doc_id',2);
formData.append('visit_level',1);
var token = ‘123456’;
var headers = {};
if (token) {
headers.Authorization = 'Bearer ' + token;
}
$.ajax({
url:'',
type:'POST',
data: formData,
processData:false,
cache:false,
contentType:false,
headers:headers,
success:function(res){
console.log(res);
},
error:function(){
alert('上传失败');
}
})
有几点需要注意的:
1. 看注释的第二行,网上说用这种方法可以获取数据但我使用了无效。所以使用第三行获取表单中的图片。
2. ajax中的 cache 和 contentType必须为false. 经测试不为false无法正常提交。
其它的在后台PHP就可以正常的使用 $_POST 和 $_FILES