Django之三種文件上傳


方式一:

通過form表單提交到后台

前端:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <form action="/upload/" method="post" enctype="multipart/form-data">
        <input type="file" name="fafafa">
        <input type="submit">
    </form>
</body>
</html>

Django 后端:

def upload(request): if request.method == 'POST':# 獲取對象
        obj = request.FILES.get('fafafa') import os
    # 上傳文件的文件名
    print(obj.name) f = open(os.path.join(BASE_DIR, 'static', 'pic', obj.name), 'wb') for chunk in obj.chunks(): f.write(chunk) f.close() return HttpResponse('OK') return render(request, 'upload/upload.html')
 

 方式二:

通過ajax提交

前端

<div>
        <input type="file" name="file" id="file_upload">
        <input type="button" value="上傳" onclick="FileUpload()">
</div>

JS:

<script src="/static/js/jquery-3.2.1.min.js"></script>
<script>
    function FileUpload() { var form_data = new FormData(); var file_info =$( '#file_upload')[0].files[0]; form_data.append('file',file_info); //if(file_info==undefined)暫且不許要判斷是否有附件
                //alert('你沒有選擇任何文件');
                //return false
 $.ajax({ url:'/upload_ajax/', type:'POST', data: form_data, processData: false,  // tell jquery not to process the data
                contentType: false, // tell jquery not to set contentType
                success: function(callback) { console.log('ok') } }); }</script>

Django 后端:

 
def upload_ajax(request): if request.method == 'POST': file_obj = request.FILES.get('file') import os f = open(os.path.join(BASE_DIR, 'static', 'pic', file_obj.name), 'wb') print(file_obj,type(file_obj)) for chunk in file_obj.chunks(): f.write(chunk) f.close() print('11111') return HttpResponse('OK')
 

注意:

前台發送ajax請求時:

processData: false, // tell jquery not to process the data
contentType: false, // tell jquery not to set contentType
必須設置
方式三:通過iframe標簽提交
httml
 <h1>測試Imframe</h1>
  <input type="text" id="url">
  <input type="button" value="點擊" onclick="iframeChange()">
  <iframe id="ifr" src=""></iframe>
   <hr/>
   <h1>基於iframe實現formt提交 </h1>
   <form action="/upload_Formdata.html" method="post" target="iframe_123" enctype="multipart/form-data">
       <iframe id="iframe_1" name="iframe_123" src="" onload="loadIframe();"></iframe>
       <input type="text" name="user">
       <input type="file" name="fafafa">
       <input type="submit">
   </form>

js:這里from標簽的target和iframe的那么保持一致,form提交后會跳轉到或者鏈接到iframe

<script src="/static/jquery-2.1.4.min.js"></script>
<script>
 function iframeChange() {
        var url = $('#url').val();
        $('#ifr').attr('src',url)
    }
    function loadIframe() {//iframe加載完后執行
        console.log(1)
        //獲取iframe內部的內容
        var str_json = $('#iframe_1').contents().find('body').text()
        var obj = JSON.parse(str_json)
        if(obj.status){
                var img = document.createElement('img');
                img.src = "/" + obj.path;
                $('#imgs').append(img);
        }
    }
    
</script>

Django 后端:

import json
def  upload_Formdata(request):
     if request.method=="GET":
         img_list=models.Img.objects.all()
         return  render(request,'upload_Formdata.html',{"img_list":img_list})
     elif request.method=="POST":
         obj=request.FILES.get('fafafa')
         file_path=os.path.join('static','upload',obj.name)
         f=open(file_path,'wb')

         for chunk in obj.chunks():
             f.write(chunk)
         f.close()

         models.Img.objects.create(path=file_path)
         ret = {'status':True,'path':file_path,'text':123}
         return  HttpResponse(json.dumps(ret))

以上是文件上傳的三種方式,在Tornado種也可以使用。

擴展:

在前段提交的時候 可以存在 checkbox 標簽, 在Django中對於這種標簽在后台獲取值時用:

  request.POST.getlist('favor', None) checkbox

其它

request.POST.get('favor', None) checkbox

 

 

 

復制代碼
def upload(request): if request.method == 'POST':# 獲取對象
        obj = request.FILES.get('fafafa') import os
    # 上傳文件的文件名
    print(obj.name) f = open(os.path.join(BASE_DIR, 'static', 'pic', obj.name), 'wb') for chunk in obj.chunks(): f.write(chunk) f.close() return HttpResponse('OK') return render(request, 'upload/upload.html')
復制代碼

 方式二:

通過ajax提交

前段

<div>
        <input type="file" name="file" id="file_upload">
        <input type="button" value="上傳" onclick="FileUpload()">
</div>

JS:

復制代碼
<script src="/static/js/jquery-3.2.1.min.js"></script>
<script>
    function FileUpload() { var form_data = new FormData(); var file_info =$( '#file_upload')[0].files[0]; form_data.append('file',file_info); //if(file_info==undefined)暫且不許要判斷是否有附件
                //alert('你沒有選擇任何文件');
                //return false
 $.ajax({ url:'/upload_ajax/', type:'POST', data: form_data, processData: false,  // tell jquery not to process the data
                contentType: false, // tell jquery not to set contentType
                success: function(callback) { console.log('ok') } }); }</script>
復制代碼

Django 后端:

復制代碼
def upload_ajax(request): if request.method == 'POST': file_obj = request.FILES.get('file') import os f = open(os.path.join(BASE_DIR, 'static', 'pic', file_obj.name), 'wb') print(file_obj,type(file_obj)) for chunk in file_obj.chunks(): f.write(chunk) f.close() print('11111') return HttpResponse('OK')
復制代碼

注意:

前台發送ajax請求時:

processData: false, // tell jquery not to process the data
contentType: false, // tell jquery not to set contentType
必須設置

方式三:
通過iframe標簽提交
前段
復制代碼
   <div>
        <form id="my_form" name="form" action="/upload_iframe/" method="POST" enctype="multipart/form-data">
            <input type="text" name="user">
            <input type="password" name="password">
            <input type="file" name="file">
            <input type="button" value="upload"  onclick="UploadFile()">
        </form>
        <iframe id='my_iframe' name='my_iframe' src="" class="hide"></iframe>
    </div>
復制代碼

JS:

復制代碼
    function UploadFile() { document.getElementById('my_iframe').onload = Testt; document.getElementById('my_form').target = 'my_iframe'; document.getElementById('my_form').submit(); } function Testt(ths){ var t = $("#my_iframe").contents().find("body").text(); console.log(t); }
復制代碼

Django 后端:

復制代碼
def upload_iframe(request): if request.method == 'POST': print(request.POST.get('user', None)) print(request.POST.get('password', None)) file_obj = request.FILES.get('file') import os f = open(os.path.join(BASE_DIR, 'static', 'pic', file_obj.name), 'wb') print(file_obj,type(file_obj)) for chunk in file_obj.chunks(): f.write(chunk) f.close() print('11111') return HttpResponse('OK')
復制代碼

參考學習:https://www.cnblogs.com/jishuweiwang/p/6140132.html

以上是文件上傳的三種方式,在Tornado種也可以使用。

擴展:

在前段提交的時候 可以存在 checkbox 標簽, 在Django中對於這種標簽在后台獲取值時用:

  request.POST.getlist('favor', None) checkbox

其它

request.POST.get('favor', None) checkbox


 



 

 
 
 
好文要頂  關注我  收藏該文   
0
0
 
 
 
« 上一篇: Django Q搜索
» 下一篇: Python random模塊
posted @  2017-11-19 10:13  TianTianLi 閱讀( 5059) 評論( 0)   編輯  收藏

 

 
 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM