zoukankan      html  css  js  c++  java
  • django中通过文件和Ajax来上传文件

    一、通过form表单来上传文件

      1.在html模板中

    <form action="/index/" method="post" enctype="multipart/form-data">
    #在form属性中写入enctype="multipart/form-data" 这样form表单才能支持数据文件的提交 {% csrf_token %} 头像<input type="file" name="touxiang" id="file"> <br> <label for="name">用户名</label> <input type="text" id="name" name="username"> <button id="btn">提交</button> </form>

      2.在views视图中写入

    def index(request):
        if request.method == 'GET':
            return render(request,'index.html')
        else:
            uname = request.POST.get('username')
            file = request.FILES.get('touxiang') #获取文件要通过.FILES.get()来获取文件数据
            file_name = file.name
            path = os.path.join(settings.BASE_DIR,'statics','img',file_name)#来拼接文件内路径
            with open(path,'wb')as f:#将文件写入本地
                for i in file:
                    f.write(i)
            return HttpResponse(uname)

      当在后端接收文件内容的时候用FILES来接收,否者只能接收到文件名,

      当用request.FILES.get('file')接收到之后,会接收到一个类似于文件句柄的数据类型,可以通过循环来读取文件,当文件是视频的时候,可以用句柄.chunks()来接收固定大小的文件,防止内存被占满

    chunks()默认返回大小经测试位65536b,也就是64kb,最大是2.5MB,是一个生成器

    二、Ajax来上传文件

      1.在HTML模板中

        $('#btn').click(function () {
            var formdata = new FormData();#ajax上传文件的时候,需要这个类型,它会将添加的键值对加工成formata的类型
            formdata.append('uname',$('#name').val());#添加键值对的方法是append,注意写法,键和值之间使用逗号隔开
            formdata.append('files',$('#file')[0].files[0]);
            formdata.append('csrfmiddlewaretoken',$('[name=csrfmiddlewaretoken]').val());#别忘了csrf_tocken
            $.ajax({
                'url':"{% url 'index' %}",
                'type':'post',
                'data':formdata,#将添加好的formdata放到data这里
                processData:false, //不处理数据
                contentType:false,//不设置内容类型
                success:function (res) {
                    console.log(res)
                }
            })
         })

      2.在视图函数中

    def index(request):
        if request.method == 'GET':
            return render(request,'index.html')
        else:
            name = request.POST.get('uname')#获取POST请求发送过来的数据
            file = request.FILES.get('tou')#获取上传文件的数据
            file_name = file.name#获取文件名
            path = os.path.join(settings.BASE_DIR,'statics','img',file_name)#拼接文件路径
            with open(path,'wb')as f:#将文件写入本地
                for i in file.chunks():
                   f.write(i)

    三、JsonResponse

    def index(request):
        if request.method == 'GET':
            return render(request,'index.html')
        else:
            # dd = {'k1':'v1','k2':'v2'}
            # dd = json.dumps(dd)
            # return HttpResponse(dd,content_type='application/json') #在发送的时候发送一个cntent_type='application/json'响应体,发送到模板中的ajax中会自动调用ajax的反序列化,就不需要手动反序列化了
            #在python中同样也有,那就是JsonResponse对象
            JsonResponse对象是HttpResponse的子类,专门用来生成JSON编码的响应
            from django.http import JsonResponse #导入JsonResponse
            dd = {'k1':'v1','k2':'v2'}
            return JsonResponse(dd) #这样就不需要自己手动序列化了,也不需要自己手动写响应体了
            dd = [11,22,33]
            return JsonResponse(dd,safe=False)#当序列化的是一个非字典的时候就需要safe=false,

    四、json序列化时间日期类型的数据的方法

    import json
    from datetime import datetime
    from datetime import date
    
    #对含有日期格式数据的json数据进行转换
    class JsonCustomEncoder(json.JSONEncoder):
        def default(self, field):
            if isinstance(field,datetime):
                return field.strftime('%Y-%m-%d %H:%M:%S')
            elif isinstance(field,date):
                return field.strftime('%Y-%m-%d')
            else:
                return json.JSONEncoder.default(self,field)
    
    
    d1 = datetime.now()
    
    dd = json.dumps(d1,cls=JsonCustomEncoder) #当再调用json的时候就不能只写要序列化的数据了,在后面要写上cls=JsonCustomEncoder
    print(dd)
  • 相关阅读:
    javasscript学习笔记 之 数组学习二 数组的所有方法
    JavaScript学习笔记之 数组方法一 堆栈 和队列
    JavaScript学习笔记:检测数组方法
    _bzoj1500 [NOI2005]维修数列【真·Splay】
    _bzoj1012 [JSOI2008]最大数maxnumber【Fenwick Tree】
    _bzoj1010 [HNOI2008]玩具装箱toy【斜率优化dp】
    _bzoj3224 Tyvj 1728 普通平衡树【Splay】
    _bzoj2002 [Hnoi2010]Bounce 弹飞绵羊【分块】
    _bzoj1001 [BeiJing2006]狼抓兔子【平面图】
    _bzoj1036 [ZJOI2008]树的统计Count【树链剖分】
  • 原文地址:https://www.cnblogs.com/wang-xing-hao/p/11266487.html
Copyright © 2011-2022 走看看