Ajax使用FormData通过模拟Form表单上传文件

当前后端分离的时候,有时候需要通过接口上传图片 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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值