django 文件上传功能的相关实例代码(简单易懂)
框架(架构)  /  管理员 发布于 6年前   114
一、新建项目,在主配置文件中,修改以下内容:
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 modelsclass User(models.Model): name = models.CharField(max_length=12) file = models.FileField(upload_to='headpics')
不要忘了在主配置文件的 INSTALLED_APPS 列表下注册该app。
然后在控制台执行如下命令:
python manage.py makemigrations uploadFilepython manage.py migrate uploadFile
三、编写路由
在主路由模块下粘贴如下代码:
from django.contrib import adminfrom django.urls import path,includeurlpatterns = [ path('admin/', admin.site.urls), path('index/',include("uploadFile.urls")),]
admin 是pycharm自动添加的,不需要的话可以删去。
然后在uploadFile下新建urls.py模块,即编写二级路由。
在二级路由下粘贴如下代码:
from django.urls import pathfrom . import viewsapp_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_404from django.http import HttpResponseimport uuid,osfrom .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: passdef 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 文件上传功能的相关实例代码,希望对大家有所帮助!
123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..路人 在
php中使用hyperf框架调用讯飞星火大模型实现国内版chatgpt功能示例中评论 教程很详细,如果加个前端chatgpt对话页面就完美了..Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号