一、基于form表单上传文件

1、html里是有一个input type="file" 和 ‘submit’的标签

2、vies.py

def fileupload(request):
    if request.method == 'POST':
        print(request.POST)
        print(request.FILES)
        # from django.core.files.uploadedfile import InMemoryUploadedFile
        print(type(request.FILES.get('myfile')))
        myfile = request.FILES.get('myfile')
        name = myfile.name
        print(name)
        with open(name,'wb') as f:
            # for line in myfile.chunks():
            #     f.write(line)
            for line in myfile:
                f.write(line)
        return HttpResponse('文件上传成功')

 

二、基于JSON上传文件

 $("#ajax_button").click(function () {
        var formdata=new FormData()
        formdata.append('name',$("#id_name2").val())
        formdata.append('myfile',$("#myfile")[0].files[0])
        $.ajax({
            url:'',
            type:'post',
            processData:false, //告诉jQuery不要去处理发送的数据
            contentType:false,// 告诉jQuery不要去设置Content-Type请求头
            data:formdata,
            success:function (data) {
                console.log(data)

            }

        })
    })
def fileupload(request):
    if request.method == 'POST':
        print(request.POST)
        print(request.FILES)
        # from django.core.files.uploadedfile import InMemoryUploadedFile
        print(type(request.FILES.get('myfile')))
        myfile = request.FILES.get('myfile')
        name = myfile.name
        print(name)
        with open(name,'wb') as f:
            # for line in myfile.chunks():
            #     f.write(line)
            for line in myfile:
                f.write(line)
        return HttpResponse('文件上传成功')

三、综上所述

  基于form表单上传文件和基于ajax上传文件后端view界面一样的不需要改动,前台需呀改动