一、新建项目,在主配置文件中,修改以下内容:
ALLOWED_HOSTS = ['127.0.0.1','localhost'] MEDIA_ROOT = os.path.join(BASE_DIR,'media') STATICFILES_DIRS = [ os.path.join(BASE_DIR, 'static'), MEDIA_ROOT]
在该项目下新建一个与 manage.py 同级的目录文件,目录名为media。
在media文件夹下新建一个子目录,作为上传文件的保存位置,这里我把该子目录命名为headpics。即模拟保存用户选择的头像文件。
二、新建APP(这里我把该app命名为uploadFile)
执行如下命令将创建app:
python manage.py startapp uploadFile
在uploadFile下的models.py文件下,粘贴如下代码:
from django.db import models class User(models.Model): name = models.CharField(max_length=12) file = models.FileField(upload_to='headpics')
不要忘了在主配置文件的 INSTALLED_APPS 列表下注册该app。
然后在控制台执行如下命令:
python manage.py makemigrations uploadFile python manage.py migrate uploadFile
三、编写路由
在主路由模块下粘贴如下代码:
from django.contrib import admin from django.urls import path,include urlpatterns = [ path('admin/', admin.site.urls), path('index/',include("uploadFile.urls")), ]
admin 是pycharm自动添加的,不需要的话可以删去。
然后在uploadFile下新建urls.py模块,即编写二级路由。
在二级路由下粘贴如下代码:
from django.urls import path from . import views app_name = 'upload' urlpatterns = [ path('file/',views.userfile,name='userfile'), path('file/detail/',views.detailFile,name='delfile'), ]
四、编写视图函数
在uploadFile的views.py文件下粘贴如下代码:
from django.shortcuts import render,get_object_or_404 from django.http import HttpResponse import uuid,os from .models import User # Create your views here. def userfile(request): return render(request,'uploadFile/uploadFile.html') def detailFile(request): if request.method == "POST": name = request.POST.get('name') file = request.FILES.get('file',None) if not file: return HttpResponse("<p>您还未上传头像!</p>") file.name = getUUID(file.name) user = User.objects.create(name=name, file=file) with open(os.path.join("D:\\upload",file.name),'wb+') as relfile: for crunk in file.chunks(): relfile.write(crunk) return HttpResponse("<p>上传成功!</p>") else: pass def getUUID(filename): id = str(uuid.uuid4()) extend = os.path.splitext(filename)[1] return id+extend
五、编写模板
在uploadFile下新建一个叫做templates的目录,在该目录下再新建一个叫做uploadFile的子目录,在该子目录下再新建一个叫做uploadFile的html文件。
在该html文件内粘贴如下代码:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>upload</title> </head> <body> <form action="{% url 'upload:delfile' %}" method="post" enctype="multipart/form-data"> {% csrf_token %} 昵称 :<input type="text" name="name"><br><br> 头像 : <input type="file" name="file"><br><br> <input type="submit" value="提交"> </form> </body> </html>
大功告成!
运行之后,在浏览器 输入 http://127.0.0.1:8000/index/file/ 可以看到界面效果,如下:
输入之后点击提交,数据就会被实时保存在数据库中,不过要记得在数据库中 file 字段保存的其实是文件的路径信息,是一个字符串。
同时,该文件也会保存在刚才创建的upload文件夹下。
可以尝试添加更多内容,比如在提交成功之后返回一个效果页面等。
总结
以上所述是小编给大家介绍的django 文件上传功能的相关实例代码,希望对大家有所帮助!
更新日志
- 雨林唱片《赏》新曲+精选集SACD版[ISO][2.3G]
- 罗大佑与OK男女合唱团.1995-再会吧!素兰【音乐工厂】【WAV+CUE】
- 草蜢.1993-宝贝对不起(国)【宝丽金】【WAV+CUE】
- 杨培安.2009-抒·情(EP)【擎天娱乐】【WAV+CUE】
- 周慧敏《EndlessDream》[WAV+CUE]
- 彭芳《纯色角3》2007[WAV+CUE]
- 江志丰2008-今生为你[豪记][WAV+CUE]
- 罗大佑1994《恋曲2000》音乐工厂[WAV+CUE][1G]
- 群星《一首歌一个故事》赵英俊某些作品重唱企划[FLAC分轨][1G]
- 群星《网易云英文歌曲播放量TOP100》[MP3][1G]
- 方大同.2024-梦想家TheDreamer【赋音乐】【FLAC分轨】
- 李慧珍.2007-爱死了【华谊兄弟】【WAV+CUE】
- 王大文.2019-国际太空站【环球】【FLAC分轨】
- 群星《2022超好听的十倍音质网络歌曲(163)》U盘音乐[WAV分轨][1.1G]
- 童丽《啼笑姻缘》头版限量编号24K金碟[低速原抓WAV+CUE][1.1G]