使用js FormData传文件流,传json(重点) 可以处理动态上传多附件处理

2 篇文章 0 订阅

先介绍js的FormData,FormData是XMLHttpRequest Level 2新增的一个接口,利用FormData对象,我们可以通过JavaScript用一些键值对来模拟一系列表单控件,我们还可以使用ajax方法来异步的提交这个"表单".使用FormData的最大优点就是我们可以异步上传一个二进制文件.
这里说下FormData的append方法,

给当前FormData对象添加一个键/值对(append)

void append(DOMString name, Blob value, optional DOMString filename);
void append(DOMString name, DOMString value);

参数值

name

字段名称.

value

字段值.可以是,或者一个字符串,如果全都不是,则该值会被自动转换成字符串.

filename

(可选) 指定文件的文件名,当value参数被指定为一个Blob对象或者一个File对象时,该文件名会被发送到服务器上,对于Blob对象来说,这个值默认为"blob".

这里要注意下value字段,如果你要填入的是一个对象,会将它转换成字符串,也就是最后传给后台的都是[object object],这样后台当然是无法解析的。下边举个例子,大家就明白了

好了,请上我们的两位同学,小明和胖虎,你们就不用发言了,我会以json的形式介绍你们的情况和个人癖好,请坐。

var json=[
         {'name':'小明','age':15,'skills':['抽烟','喝酒','烫头'],'family':{'father':'大明','mohter':'小红'}},
         {'name':'胖虎','age':17,'skills':['打架','打架','还是打架'],'family':{'father':'佐藤','mohter':'爱田'}},
     ]

 

首先我们先试一下,把小明的family对象传给后台。

var data=new FormData()
     data.append('family',json[0].family)
     $.ajax({
         url:'demo.php',
         type: "Post",
         dataType: "json",
         cache: false,//上传文件无需缓存
         processData: false,//用于对data参数进行序列化处理 这里必须false
         contentType: false, //必须
         data:data,
         success:function (res) {
             console.log(res);
         },
         error:function (error) {
             console.log(error);
         }
     })

结果:


被解析成了object object,有人该说了,你把它用JSON.stringify序列化之后不就行了,然后后端配合,再解码成json,对,这样确实行,但不要忘了,咱们还是需要传文件流的,文件流被序列化之后会被转化成一个空对象,这样后台就无法识别。由于时间原因,这里就不演示反面案例了。
这里我们要用两个语法
1.a['b']等于a.b
2.c[0]取得是c数组的第一项
正确方法:

 

var data=new FormData()
for(var i=0,len=json.length;i<len;i++){
        data.append('json['+i+'][name]',json[i].name)
        data.append('json['+i+'][age]',json[i].age)
        data.append('json['+i+'][family][father]',json[i].family.father)
        data.append('json['+i+'][family][mother]',json[i].family.mohter)
        for(var j=0,len2=json[i].skills.length;j<len2;j++){
            data.append('skills['+i+']['+j+']',json[i].skills[j])
        }
    }
     $.ajax({
         url:'demo.php',
         type: "Post",
         dataType: "json",
         cache: false,//上传文件无需缓存
         processData: false,//用于对data参数进行序列化处理 这里必须false
         contentType: false, //必须
         data:data,
         success:function (res) {
             console.log(res);
         },
         error:function (error) {
             console.log(error);
         }
     })

之后,我们再给小明和胖虎每人上传一张个人写真照(利用input
file,文件流)
这里我们利用input上传时的file对象,
附上代码:

<input type="file" id="upload">
$('#upload').on('change',function (e) {
         var file = e.target.files[0];
         console.log(file);
         data.append('json[0][image]',file)
     })

这个file对象是一个含有二进制文件,打印为:

 

 

这个对象如果直接序列化,会被转化为一个空对象,后台无法识别,最后附上vue版代码:

<input type="file" @click="upload" id="upload">
upload:function (e) {
                var file = e.target.files[0];
                //由于时间和条件原因,这里只给小明上传一张写真照
                data.append('json[0][image]',file)
                for(var i=0,len=json.length;i<len;i++){
                    data.append('json['+i+'][name]',json[i].name)
                    data.append('json['+i+'][age]',json[i].age)
                    data.append('json['+i+'][family][father]',json[i].family.father)
                    data.append('json['+i+'][family][mother]',json[i].family.mohter)
                    for(var j=0,len2=json[i].skills.length;j<len2;j++){
                        data.append('skills['+i+']['+j+']',json[i].skills[j])
                    }
                }
                axios.post(api.sendJSON,data,{
                    headers: {
                        "Content-Type": "multipart/form-data"
                    }
                }).then(function (res) {
                    console.log(res);
                }).catch(function (error) {
                    console.log(error);
                })
            },



作者:心隐居士
链接:https://www.jianshu.com/p/80e133a16d5e
来源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在 Django 中处理前端递的文件,可以通过以下步骤实现: 1. 在前端,使用 JavaScript 将文件发送给 Django 后端。你可以使用 Fetch API 或 XMLHttpRequest 来发送文件。 2. 在 Django 的视图函数或类中,处理 POST 请求并获取递的文件数据。 3. 可以使用 Django 的文件操作来处理接收到的文件。你可以选择将文件保存到服务器上的指定位置,或者对文件进行其他操作(如读取内容、转换格式等)。 4. 返回适当的响应给前端,告知文件处理的结果。 下面是一个简单的示例代码: ```javascript // frontend.js const fileInput = document.getElementById('file-input'); fileInput.addEventListener('change', () => { const file = fileInput.files[0]; const formData = new FormData(); formData.append('file', file); fetch('/upload/', { method: 'POST', body: formData }) .then(response => response.json()) .then(data => { console.log(data); }) .catch(error => { console.error(error); }); }); ``` ```python # views.py from django.http import JsonResponse def upload_file(request): if request.method == 'POST': file = request.FILES['file'] # 处理文件,比如保存到服务器上的指定位置 with open('path/to/save/file.ext', 'wb+') as destination: for chunk in file.chunks(): destination.write(chunk) # 返回适当的响应给前端 return JsonResponse({'message': '文件成功'}) return JsonResponse({'message': '无效的请求'}) ``` 在这个示例中,我们使用 JavaScript 监听文件输入框的变化事件,获取用户选择的文件,并将其作为文件发送给 Django 后端。然后,在 Django 的视图函数 `upload_file` 中,我们使用 `request.FILES` 获取递的文件数据,并将其保存到服务器上的指定位置(`path/to/save/file.ext`)。最后,我们返回一个 JSON 响应给前端,告知文件的结果。 请根据你的需求修改代码来满足你的实际情况。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值