django 文件上传功能的相关实例代码

**

django 文件上传功能的相关实例代码**

**

一、新建项目,在主配置文件中,修改以下内容:

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(“

您还未上传头像!

”)
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(“

上传成功!

”)
else:
pass
def getUUID(filename):
id = str(uuid.uuid4())
extend = os.path.splitext(filename)[1]
return id+extend
五、编写模板

在uploadFile下新建一个叫做templates的目录,在该目录下再新建一个叫做uploadFile的子目录,在该子目录下再新建一个叫做uploadFile的html文件。

在该html文件内粘贴如下代码:

upload {% csrf_token %} 昵称 :

头像 :  

大功告成!

运行之后,在浏览器 输入 http://127.0.0.1:8000/index/file/ 可以看到界面效果,如下:

输入之后点击提交,数据就会被实时保存在数据库中,不过要记得在数据库中 file 字段保存的其实是文件的路径信息,是一个字符串。

同时,该文件也会保存在刚才创建的upload文件夹下。

可以尝试添加更多内容,比如在提交成功之后返回一个效果页面等。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值