django修改头像的功能...html
1.在表单中加入enctype="multipart/form-data;python
关于表单中enctype的介绍:http://www.w3school.com.cn/tags/att_form_enctype.asp数据库
处理表单的视图会在request中接受到上传文件的数据。FILES是个字典,它包含每一个FileField的键 django
(或者ImageField,FileField的子类)。这样的话就能够用request.FILES['File']来存放表单中的这些数据了。 session
注意request.FILES只有在请求方法为POST,而且发送请求的<form>拥有enctype="multipart/form-data属性时,url
以下图所示:code
提交后显示图片信息:orm
若是不加enctype="multipart/form-data:得不到图片信息,只有路径htm
2.上传图片
因为model中photo字段存储的是路径,因此首先要把图片保存在图片对应的文件夹下。
保存图片中使用到了PIL库,对图片进行各类操做----参考资料:廖雪峰--PIL;PIL官方文档
我使用的功能简单,只是保存图片而已。代码:
photo=request.FILES['photo'] if photo: phototime= request.user.username+str(time.time()).split('.')[0] photo_last=str(photo).split('.')[-1] photoname='photos/%s.%s'%(phototime,photo_last)
img=Image.open(photo) img.save('media/'+photoname)
3.将图片路径更新到数据库
调用update()方法便可。
注:update()方法对于任何结果集(QuerySet)均有效。经过get()方法的到的不是QuerySet,
因此,不能够update,另外get()方法达不到数据和返回条数大于1条的时候都会报错。
print type( UserInfo.objects.get(id=userinfo_id)) ---> <class 'Account.models.UserInfo'> print type( UserInfo.objects.filter(id=userinfo_id))----> <class 'django.db.models.query.QuerySet'>
相关代码以下:
models.py
class UserInfo(models.Model): user=models.OneToOneField(User) photo=models.ImageField(upload_to='photos',default='user1.jpg') def __unicode__(self): return self.user.username
html代码
<form action="/updateinfo" method="POST" enctype="multipart/form-data"> <div class="updateImg"> <img src="{{ account.photo.url }}" alt=""/> </div> <input name="photo" type="file" id="exampleInputFile"> <button id="photo" class="btn btn-danger" type="submit">上传头像</button>
views.py
def updateInfo(request): if request.method=='POST': photo=request.FILES['photo'] if photo: phototime= request.user.username+str(time.time()).split('.')[0] photo_last=str(photo).split('.')[-1] photoname='photos/%s.%s'%(phototime,photo_last) img=Image.open(photo) img.save('media/'+photoname) count=UserInfo.objects.filter(user=request.user).update( photo=photoname ) if count: # 设置一个session,而后跳转到对应的页面,此处简易写写 return HttpResponse('上传成功') else: return HttpResponse('上传失败') return HttpResponse('图片为空')
参考:http://bluecrystal.iteye.com/blog/233030
http://python.usyiyi.cn/django/index.html
============若有错误欢迎指正,转载请注明出处==============