您好,登录后才能下订单哦!
密码登录
登录注册
点击 登录注册 即表示同意《亿速云用户服务条款》
小编这次要给大家分享的是用代码实例详解Django如何实现前台上传并显示图片,文章内容丰富,感兴趣的小伙伴可以来了解一下,希望大家阅读完这篇文章之后能够有所收获。
1. 前台
templates/upload/upload.html
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <form action="/myupload/upload/" method="post" enctype="multipart/form-data"> {% csrf_token %} 名字:<input type="text" name="name"><br> 头像:<input type="file" name="avator"><br> <input type="submit" value="提交"> </form> </body> </html>
2. 项目设定
settings.py
#添加
ALLOW_UPLOAD = ['jpg', 'png', 'jpeg']
3.app设定
urls.py
from django.contrib import admin from django.urls import path, register_converter, re_path from . import views urlpatterns = [ path('', views.index, name='index'), # 上传首页 path('upload/', views.upload), # 上传图片 ]
views.py
from django.shortcuts import render from .models import User,Article from django.http import HttpResponse from django.conf import settings from datetime import datetime import os from django.shortcuts import redirect, reverse import hashlib # Create your views here. def index(request): users = User.objects.all() article = Article.objects.all() return render(request, 'myupload/index.html', locals()) def upload(request): if request.method == 'GET': return render(request, 'myupload/upload.html') else: name = request.POST.get('name') pic = request.FILES.get('avator') media_root = settings.MEDIA_ROOT # media allow_upload = settings.ALLOW_UPLOAD # ALLOW_UPLOAD # path = 'upload/{}/{}/{}/'.format(datetime.now().year, datetime.now().month, datetime.now().day) '{:02d}'.format path = 'upload/{}/{}/{}/'.format(datetime.now().year,'{:02d}'.format(datetime.now().month), '{:02d}'.format(datetime.now().day)) full_path = media_root + '/' + path # full_path = 'media/upload/2019/12/20' if not os.path.exists(full_path): # 判断路径是否存在 os.makedirs(full_path) # 创建此路径 # 要不要改图片的名字 生成hash # 这块要不要判断图片类型 .jpg .png .jpeg # '/../../../myviews/setting.py' print(pic) print(full_path) print(full_path+pic.name) if pic.name.split('.')[-1] not in allow_upload: return HttpResponse('fail') with open(full_path + '/' + pic.name, 'wb') as f: for c in pic.chunks(): # 相当于切片 f.write(c) User.objects.create(name=name, avator=path + pic.name) return redirect('myupload:index')
Django实现后台上传并显示图片功能
看完这篇关于用代码实例详解Django如何实现前台上传并显示图片的文章,如果觉得文章内容写得不错的话,可以把它分享出去给更多人看到。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。