上传图片
当Django在处理文件上传的时候,文件数据被保存在request.FILES
FILES中的每个键为中的name
注意:FILES只有在请求的方法为POST 且提交的带有enctype=”multipart/form-data” 的情况下才会包含数据。否则,FILES 将为一个空的类似于字典的对象
使用模型处理上传文件:将属性定义成models.ImageField类型
pic=models.ImageField(upload_to=’cars/’)
注意:如果属性类型为ImageField需要安装包Pilow
pip install Pillow==3.4.1
图片存储路径
在项目根目录下创建media文件夹
图片上传后,会被保存到“/static/media/cars/图片文件”
打开settings.py文件,增加media_root项
MEDIA_ROOT=os.path.join(BASE_DIR,”static/media”)
使用django后台管理,遇到ImageField类型的属性会出现一个file框,完成文件上传
手动上传的模板代码
第一步在应用根目录下创建/static/media这样的文件夹
第二步配置静态文件目录。在seting.py文件填上静态文件目录。
STATIC_URL = '/static/'
TEMPLATE_DIRS = (os.path.join(BASE_DIR, 'templates'),)
STATICFILES_DIRS=[
os.path.join(BASE_DIR,'static'),
]
MEDIA_ROOT=os.path.join(BASE_DIR,'static/media/')
文件上传模板的编写。
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Titletitle>
head>
<body>
<form action="uploadHandle" method="post" enctype="multipart/form-data">
{% csrf_token %}
<input type="file" name="pic1">
<input type="submit" value="上传">
form>
body>
html>
视图
from django.shortcuts import render
from django.http import HttpResponse
import os
from django.conf import settings
from booktest.models import *
from django.core.paginator import Paginator
# Create your views here.
def index(request):
return render(request,'booktest/index.html')
def MyExp(request):
a=int('abc')
return HttpResponse('hello')
def uploadPic(request):
return render(request,'booktest/uploadPic.html')
def uploadHandle(request):
pic1=request.FILES['pic1']
#构造文件的存储路径
picName=os.path.join(settings.MEDIA_ROOT,pic1.name)
#打开这个文件;
print(picName)
with open(picName,'wb+') as pic:
for c in pic1.chunks():
pic.write(c)
return HttpResponse('')
配置url
from django.conf.urls import url
from booktest import views
urlpatterns=[
url(r'^$',views.index),
url(r'^myExp$',views.MyExp),
url(r'^uploadPic',views.uploadPic),
url(r'^uploadHandle$',views.uploadHandle),
url(r'^herolist/(\d*)$',views.herolist)
]
最后想说的,这些代码都是基于Python3编写,并且测试成功了。