欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品

主頁 > 知識庫 > django上傳文件的三種方式

django上傳文件的三種方式

熱門標簽:悟空智電銷機器人6 外呼不封號系統 電信營業廳400電話申請 幫人做地圖標注收費算詐騙嗎 蘇州電銷機器人十大排行榜 溫州旅游地圖標注 江蘇房產電銷機器人廠家 荊州云電銷機器人供應商 遼寧400電話辦理多少錢

Django文件上傳需要考慮的重要事項

文件或圖片一般通過表單進行。用戶在前端點擊文件上傳,然后以POST方式將數據和文件提交到服務器。服務器在接收到POST請求后需要將其存儲在服務器上的某個地方。Django默認的存儲地址是相對于根目錄的/media/文件夾,存儲的默認文件名就是文件本來的名字。上傳的文件如果不大于2.5MB,會先存入服務器內存中,然后再寫入磁盤。如果上傳的文件很大,Django會把文件先存入臨時文件,再寫入磁盤。

Django默認處理方式會出現一個問題,所有文件都存儲在一個文件夾里。不同用戶上傳的有相同名字的文件可能會相互覆蓋。另外用戶還可能上傳一些不安全的文件如js和exe文件,我們必需對允許上傳文件的類型進行限制。因此我們在利用Django處理文件上傳時必需考慮如下3個因素:

  • 設置存儲上傳文件的文件夾地址
  • 對上傳文件進行重命名
  • 對可接受的文件類型進行限制(表單驗證)

注意:以上事項對于上傳圖片是同樣適用的。

Django文件上傳的3種常見方式

Django文件上傳一般有3種方式(如下所示)。我們會針對3種方式分別提供代碼示范。

  • 使用一般的自定義表單上傳,在視圖中手動編寫代碼處理上傳的文件
  • 使用由模型創建的表單(ModelForm)上傳,使用form.save()方法自動存儲
  • 使用Ajax實現文件異步上傳,上傳頁面無需刷新即可顯示新上傳的文件

Ajax文件上傳部分見Django與Ajax交互篇。

項目創建與設置

我們先使用django-admin startproject命令創建一個叫file_project的項目,然后cd進入file_project, 使用python manage.py startapp創建一個叫file_upload的app。

我們首先需要將file_upload這個app加入到我們項目里,然后設置/media/和/STATIC_URL/文件夾。我們上傳的文件都會放在/media/文件夾里。我們還需要使用css和js這些靜態文件,所以需要設置STATIC_URL。

#file_project/settings.py

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'file_upload',# 新增
]

STATIC_URL = '/static/'
STATICFILES_DIRS = [os.path.join(BASE_DIR, "static"), ]

MEDIA_ROOT = os.path.join(BASE_DIR, 'media')
MEDIA_URL = '/media/'

#file_project/urls.py
from django.contrib import admin
from django.urls import path, include
from django.conf import settings
from django.conf.urls.static import static

urlpatterns = [
    path('admin/', admin.site.urls),
    path('file/', include("file_upload.urls")),
] + static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT)

創建模型

使用Django上傳文件創建模型不是必需,然而如果我們需要對上傳文件進行系統化管理,模型還是很重要的。我們的File模型包括file和upload_method兩個字段。我們通過upload_to選項指定了文件上傳后存儲的地址,并對上傳的文件名進行了重命名。

#file_upload/models.py
from django.db import models
import os
import uuid

# Create your models here.
# Define user directory path
def user_directory_path(instance, filename):
    ext = filename.split('.')[-1]
    filename = '{}.{}'.format(uuid.uuid4().hex[:10], ext)
    return os.path.join("files", filename)

class File(models.Model):
    file = models.FileField(upload_to=user_directory_path, null=True)
    upload_method = models.CharField(max_length=20, verbose_name="Upload Method")

注意:如果你不使用ModelForm,你還需要手動編寫代碼存儲上傳文件。

URLConf配置

本項目一共包括3個urls, 分別對應普通表單上傳,ModelForm上傳和顯示文件清單。

#file_upload/urls.py
from django.urls import re_path, path
from . import views

# namespace
app_name = "file_upload"

urlpatterns = [
    # Upload File Without Using Model Form
    re_path(r'^upload1/$', views.file_upload, name='file_upload'),

    # Upload Files Using Model Form
    re_path(r'^upload2/$', views.model_form_upload, name='model_form_upload'),

    # View File List
    path('file/', views.file_list, name='file_list'),

]

使用一般表單上傳文件

我們先定義一個一般表單FileUploadForm,并通過clean方法對用戶上傳的文件進行驗證,如果上傳的文件名不以jpg, pdf或xlsx結尾,將顯示表單驗證錯誤信息。關于表單的自定義和驗證更多內容見Django基礎: 表單forms的設計與使用。

#file_upload/forms.py

from django import forms
from .models import File

# Regular form
class FileUploadForm(forms.Form):
    file = forms.FileField(widget=forms.ClearableFileInput(attrs={'class': 'form-control'}))
    upload_method = forms.CharField(label="Upload Method", max_length=20,
                                   widget=forms.TextInput(attrs={'class': 'form-control'}))
    def clean_file(self):
        file = self.cleaned_data['file']
        ext = file.name.split('.')[-1].lower()
        if ext not in ["jpg", "pdf", "xlsx"]:
            raise forms.ValidationError("Only jpg, pdf and xlsx files are allowed.")
        # return cleaned data is very important.
        return file

注意: 使用clean方法對表單字段進行驗證時,別忘了return驗證過的數據,即cleaned_data。只有返回了cleaned_data, 視圖中才可以使用form.cleaned_data.get(‘xxx')獲取驗證過的數據。

對應一般文件上傳的視圖file_upload方法如下所示。當用戶的請求方法為POST時,我們通過form.cleaned_data.get('file')獲取通過驗證的文件,并調用自定義的handle_uploaded_file方法來對文件進行重命名,寫入文件。如果用戶的請求方法不為POST,則渲染一個空的FileUploadForm在upload_form.html里。我們還定義了一個file_list方法來顯示文件清單。

#file_upload/views.py

from django.shortcuts import render, redirect
from .models import File
from .forms import FileUploadForm, FileUploadModelForm
import os
import uuid
from django.http import JsonResponse
from django.template.defaultfilters import filesizeformat

# Create your views here.


# Show file list
def file_list(request):
    files = File.objects.all().order_by("-id")
    return render(request, 'file_upload/file_list.html', {'files': files})

# Regular file upload without using ModelForm
def file_upload(request):
    if request.method == "POST":
        form = FileUploadForm(request.POST, request.FILES)
        if form.is_valid():
            # get cleaned data
            upload_method = form.cleaned_data.get("upload_method")
            raw_file = form.cleaned_data.get("file")
            new_file = File()
            new_file.file = handle_uploaded_file(raw_file)
            new_file.upload_method = upload_method
            new_file.save()
            return redirect("/file/")
    else:
        form = FileUploadForm()

    return render(request, 'file_upload/upload_form.html', 
                  {'form': form, 'heading': 'Upload files with Regular Form'}
                 )

def handle_uploaded_file(file):
    ext = file.name.split('.')[-1]
    file_name = '{}.{}'.format(uuid.uuid4().hex[:10], ext)

    # file path relative to 'media' folder
    file_path = os.path.join('files', file_name)
    absolute_file_path = os.path.join('media', 'files', file_name)

    directory = os.path.dirname(absolute_file_path)
    if not os.path.exists(directory):
        os.makedirs(directory)

    with open(absolute_file_path, 'wb+') as destination:
        for chunk in file.chunks():
            destination.write(chunk)

    return file_path

注意:

  • handle_uploaded_file方法里文件寫入地址必需是包含/media/的絕對路徑,如果/media/files/xxxx.jpg,而該方法返回的地址是相對于/media/文件夾的地址,如/files/xxx.jpg。存在數據中字段的是相對地址,而不是絕對地址。
  • 構建文件寫入絕對路徑時請用os.path.join方法,因為不同系統文件夾分隔符不一樣。寫入文件前一個良好的習慣是使用os.path.exists檢查目標文件夾是否存在,如果不存在先創建文件夾,再寫入。

上傳表單模板upload_form.html代碼如下:

#file_upload/templates/upload_form.html
{% extends "file_upload/base.html" %}
{% block content %}
{% if heading %}
h3>{{ heading }}/h3>
{% endif %}

form action="" method="post" enctype="multipart/form-data" >
  {% csrf_token %}
  {{ form.as_p }}
 button class="btn btn-info form-control " type="submit" value="submit">Upload/button>
/form>
{% endblock %} 

顯示文件清單模板file_list.html代碼如下所示:

# file_upload/templates/file_list.html
{% extends "file_upload/base.html" %}

{% block content %}
h3>File List/h3>
p> a href="/file/upload1/" rel="external nofollow" >RegularFormUpload/a> | a href="/file/upload2/" rel="external nofollow" >ModelFormUpload/a>
    | a href="/file/upload3/" rel="external nofollow" >AjaxUpload/a>/p>
{% if files %}
table class="table table-striped">
    tbody>
    tr>
        td>Filename  URL/td>
        td>Filesize/td>
        td>Upload Method/td>
    /tr>
    {% for file in files %}
    tr>
        td>a href="{{ file.file.url }}" rel="external nofollow" >{{ file.file.url }}/a>/td>
        td>{{ file.file.size | filesizeformat }}/td>
        td>{{ file.upload_method }}/td>
    /tr>
    {% endfor %}
    /tbody>
/table>

{% else %}

p>No files uploaded yet. Please click a href="{% url 'file_upload:file_upload' %}" rel="external nofollow" >here/a>
    to upload files./p>
{% endif %}
{% endblock %}

注意: 

  • 對于上傳的文件我們可以調用file.url, file.name和file.size來查看上傳文件的鏈接,地址和大小。
  • 上傳文件的大小默認是以B顯示的,數字非常大。使用Django模板過濾器filesizeformat可以將文件大小顯示為人們可讀的方式,如MB,KB。

使用ModelForm上傳文件

使用ModelForm上傳是小編我推薦的上傳方式,前提是你已經在模型中通過upload_to選項自定義了用戶上傳文件存儲地址,并對文件進行了重命名。我們首先要自定義自己的FileUploadModelForm,由File模型重建的。代碼如下所示:

#file_upload/forms.py
from django import forms
from .models import File

# Model form
class FileUploadModelForm(forms.ModelForm):
    class Meta:
        model = File
        fields = ('file', 'upload_method',)
        widgets = {
            'upload_method': forms.TextInput(attrs={'class': 'form-control'}),
            'file': forms.ClearableFileInput(attrs={'class': 'form-control'}),
        }

    def clean_file(self):
        file = self.cleaned_data['file']
        ext = file.name.split('.')[-1].lower()
        if ext not in ["jpg", "pdf", "xlsx"]:
            raise forms.ValidationError("Only jpg, pdf and xlsx files are allowed.")
        # return cleaned data is very important.
        return file

使用ModelForm處理文件上傳的視圖model_form_upload方法非常簡單,只需調用form.save()即可,無需再手動編寫代碼寫入文件。

#file_upload/views.py

from django.shortcuts import render, redirect
from .models import File
from .forms import FileUploadForm, FileUploadModelForm
import os
import uuid
from django.http import JsonResponse
from django.template.defaultfilters import filesizeformat

# Create your views here.
# Upload File with ModelForm

def model_form_upload(request):
    if request.method == "POST":
        form = FileUploadModelForm(request.POST, request.FILES)
        if form.is_valid():
            form.save() # 一句話足以
            return redirect("/file/")
    else:
        form = FileUploadModelForm()

    return render(request, 'file_upload/upload_form.html', 
                  {'form': form,'heading': 'Upload files with ModelForm'}
                 )

模板跟前面一樣,這里就不展示了。

GitHub源碼地址

https://github.com/shiyunbo/django-file-upload-download

小結

本文提供并解讀了利用Django上傳文件的3種主要方式(一般表單上傳,ModelForm上傳和Ajax上傳)及示范代碼。

以上就是django上傳文件的三種方式的詳細內容,更多關于django上傳文件的資料請關注腳本之家其它相關文章!

您可能感興趣的文章:
  • Django 如何實現文件上傳下載
  • Django和Ueditor自定義存儲上傳文件的文件名
  • 詳解Django自定義圖片和文件上傳路徑(upload_to)的2種方式
  • 基于django和dropzone.js實現上傳文件
  • python中Django文件上傳方法詳解
  • Django后端分離 使用element-ui文件上傳方式
  • Django Admin 上傳文件到七牛云的示例代碼
  • Django實現任意文件上傳(最簡單的方法)
  • Django 解決上傳文件時,request.FILES為空的問題
  • Django中文件上傳和文件訪問微項目的方法
  • django 文件上傳功能的相關實例代碼(簡單易懂)

標簽:臺灣 宿遷 欽州 景德鎮 濟南 喀什 三沙 黃山

巨人網絡通訊聲明:本文標題《django上傳文件的三種方式》,本文關鍵詞  django,上傳,文件,的,三種,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《django上傳文件的三種方式》相關的同類信息!
  • 本頁收集關于django上傳文件的三種方式的相關信息資訊供網民參考!
  • 推薦文章
    欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品
  • <rt id="w000q"><acronym id="w000q"></acronym></rt>
  • <abbr id="w000q"></abbr>
    <rt id="w000q"></rt>
    国产人妖乱国产精品人妖| 国产成人精品亚洲777人妖 | 91麻豆精品国产91久久久| 亚洲另类中文字| 99麻豆久久久国产精品免费| 成人自拍小视频| 国产精品乱码一区二三区小蝌蚪| 国产精品123| 三级av在线免费观看| 国产精品蜜臀在线观看| 成人动漫一区二区在线| 国产88在线观看入口| 亚洲日本欧美天堂| 亚洲成人av免费观看| 欧美日韩精品欧美日韩精品一| 亚洲一区二区三区在线看| 香蕉视频免费网站| 欧美高清hd18日本| 奇米一区二区三区| 1024在线看片| 国产精品久久久久久亚洲伦| www.视频一区| 欧美日韩一区在线观看| 日韩精品国产精品| 中文字幕有码在线播放| 亚洲国产精华液网站w | 高清国产午夜精品久久久久久| 天天色影综合网| 亚洲免费观看在线观看| 中国特级黄色大片| 欧美videos中文字幕| 国产一区二区三区在线观看免费| 亚洲一区电影在线观看| 亚洲人成网站色在线观看| 年下总裁被打光屁股sp| 欧美大片日本大片免费观看| 国产麻豆成人精品| 在线一区二区视频| 日韩电影一二三区| 国产又粗又猛又爽又黄的视频小说| 亚洲欧洲99久久| www男人天堂| wwww国产精品欧美| av午夜一区麻豆| 91精品国产高清一区二区三区蜜臀| 精品亚洲国产成人av制服丝袜| 中文字幕在线有码| 午夜国产精品一区| 亚洲aaa视频| 亚洲国产毛片aaaaa无费看| 精品无码人妻一区| 中文字幕色av一区二区三区| www.男人天堂| 国产精品无圣光一区二区| 中文字幕av一区二区三区人妻少妇 | 成人免费看片app下载| 欧美日韩国产首页在线观看| 激情五月婷婷综合网| 欧美在线免费观看亚洲| 久久99国内精品| 欧美在线观看一区二区| 九九**精品视频免费播放| 在线看国产一区二区| 九一九一国产精品| 欧美色视频在线| 国产一区二区三区免费在线观看| 在线一区二区三区四区五区| 精品一区二区久久| 欧美精品在线一区二区三区| 国产高清不卡二三区| 欧美一区三区四区| aa级大片欧美| 久久久精品黄色| 人妻体内射精一区二区三区| 国产精品三级久久久久三级| 丰满少妇一区二区三区| 亚洲欧美日韩国产一区二区三区| 免费看91的网站| 亚洲大片在线观看| 青青青在线免费观看| 男女男精品视频| 欧美亚洲综合另类| 国产999精品久久| 精品黑人一区二区三区久久 | 国产精品视频第一区| 好吊一区二区三区视频| 亚洲人成亚洲人成在线观看图片| 一级特黄曰皮片视频| 日韩激情中文字幕| 欧美三级日韩在线| 成人午夜免费视频| 国产日本欧美一区二区| 国产交换配乱淫视频免费| 亚洲第四色夜色| 日本丶国产丶欧美色综合| 国产高清一区日本| 精品福利二区三区| 女同毛片一区二区三区| 亚洲综合另类小说| 色欧美片视频在线观看| 丰满亚洲少妇av| 久久久一区二区三区| 极品白嫩丰满美女无套| 亚洲国产综合在线| 欧洲色大大久久| 99视频在线精品| 中文字幕中文字幕一区| 99精品中文字幕| 国产一区二区在线免费观看| 欧美xxxxx裸体时装秀| 中文字幕 亚洲一区| 亚洲成人av一区二区三区| 欧美色综合天天久久综合精品| 成人开心网精品视频| 国产精品视频在线看| 911国产在线| 国产东北露脸精品视频| 国产欧美日韩在线看| 国精品人伦一区二区三区蜜桃| 国产一区二区精品久久| 久久久久国产精品麻豆| 99在线视频免费| 国产精华液一区二区三区| 国产日本亚洲高清| 在线视频这里只有精品| 国产成人精品三级| 国产精品久久久久婷婷| 国产88在线观看入口| 99久久久免费精品国产一区二区| 成人免费一区二区三区在线观看| 国产67194| 99re成人在线| 亚洲线精品一区二区三区| 欧美日本国产一区| 亚洲 欧美 日韩在线| 热久久久久久久| 精品1区2区在线观看| 懂色av粉嫩av浪潮av| 国产福利不卡视频| 日韩理论在线观看| 欧美老女人第四色| 精品无码在线视频| 国内成+人亚洲+欧美+综合在线 | 欧美在线视频日韩| 久久免费精品国产| 乱中年女人伦av一区二区| 久久久国产一区二区三区四区小说 | 欧美一区国产二区| 欧美大波大乳巨大乳| 国产精品综合视频| 国产精品成人一区二区三区夜夜夜 | 日韩精品一区二区亚洲av性色| 成人高清在线视频| 亚洲高清不卡在线观看| 日韩精品一区二区三区视频在线观看 | 国产国语性生话播放| 国产主播一区二区三区| 国产精品美女久久久久aⅴ| 欧美四级电影网| 亚洲精品乱码久久久久久不卡| 美女任你摸久久| 国产欧美日韩另类视频免费观看| 色哟哟一区二区| 污片免费在线观看| 国产馆精品极品| 亚洲香肠在线观看| 久久免费看少妇高潮| 一本一道久久a久久精品| 一边摸一边做爽的视频17国产 | 首页欧美精品中文字幕| 国产欧美一区二区精品性色 | 亚洲国产综合视频在线观看| 精品国产乱子伦一区| 99久久婷婷国产综合| 精品久久久久一区二区| 国产一区不卡在线| 一片黄亚洲嫩模| 久久九九久久九九| 欧亚一区二区三区| 中文字幕第24页| 极品人妻一区二区| 激情成人午夜视频| 亚洲第一会所有码转帖| 国产三级一区二区| 欧美片在线播放| 国产午夜精品理论片| 一级国产黄色片| 99麻豆久久久国产精品免费| 免费成人深夜小野草| 亚洲欧美电影一区二区| 精品国产乱码久久久久久浪潮 | 加勒比精品视频| 成人av电影在线| 美国欧美日韩国产在线播放| 亚洲欧美日韩系列| 久久久久久久久久美女| 在线播放日韩导航| 综合五月激情网| 波多野结衣片子| 美国黄色一级视频|