博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
django 上传图片到固定目录
阅读量:7146 次
发布时间:2019-06-29

本文共 2159 字,大约阅读时间需要 7 分钟。

hot3.png

1.在表单中加入enctype="multipart/form-data;

关于表单中enctype的介绍:

处理表单的视图会在request中接受到上传文件的数据。FILES是个字典,它包含每个FileField的键

(或者ImageField,FileField的子类)。这样的话就可以用request.FILES['File']来存放表单中的这些数据了。 

注意request.FILES只有在请求方法为POST,并且发送请求的<form>拥有enctype="multipart/form-data属性时,才会包含数据。否则request.FILES为空

如下图所示:

提交后显示图片信息:

如果不加enctype="multipart/form-data:得不到图片信息,只有路径

 

2.上传图片

由于model中photo字段存储的是路径,所以首先要把图片保存在图片对应的文件夹下。

保存图片中使用到了PIL库,对图片进行各种操作----参考资料:;

我使用的功能简单,只是保存图片而已。代码:

1

2

3

4

5

6

7

8

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)<br><br>      

            img=Image.open(photo)

            img.save('media/'+photoname)

3.将图片路径更新到数据库

调用update()方法即可。

注:update()方法对于任何结果集(QuerySet)均有效。通过get()方法的到的不是QuerySet,

所以,不可以update,另外get()方法达不到数据和返回条数大于1条的时候都会报错。

1

2

3

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

1

2

3

4

5

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代码

1

2

3

4

5

6

7

<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

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

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('图片为空')

 

 

转载于:https://my.oschina.net/zhangyangyang/blog/738025

你可能感兴趣的文章
windows常用命令
查看>>
C# 配置错误定义了重复的“system.web.extensions/scripting/scriptResourceHandler”节
查看>>
[置顶] API相关工作的个人总结_工作中琐碎细节的总结二
查看>>
Oracle约束操作
查看>>
Android中View绘制流程以及invalidate()等相关方法分析
查看>>
Html5 Geolocation获取地理位置信息(转)
查看>>
VirtualBox的四种网络连接方式
查看>>
【iCore3 双核心板_ uC/OS-III】例程六:信号量——共享资源
查看>>
NSSCanner 提取 指定 字符串
查看>>
解剖SQLSERVER 第十七篇 使用 OrcaMDF Corruptor 故意损坏数据库(译)
查看>>
转:vector的reserve和resize
查看>>
iOS - OC NSDictionary 字典
查看>>
李洪强iOS经典面试题142-第三方框架及其管理
查看>>
Linux安装MediaWiki
查看>>
设计模式--外观(Facade)模式
查看>>
雪85年前奥运之耻,马云的中国技术让世界侧目!
查看>>
总有戏精想害朕?那是你没试过百度人脸核身
查看>>
突破2万美元的比特币与其背后的区块链技术
查看>>
Q新闻丨百度搜索故障,工信部责令其深入调查并整改;亚马逊发布关于 AWS S3 服务中断故障公告;微软向中国政府披露源代码...
查看>>
端到端的实力大爆发!华为发布首款商用5G多模终端芯片
查看>>