django 读取图片到页面实例


Posted in Python onMarch 27, 2020

首先,我们看看models.py里的模型,有个upload_to参数,为了和过去一刀两断,楼主决定给upload_to赋值一个新的值叫avatar/,这个参数的意思是把文件上传到MEDIA_ROOT/avatar/下面。

既然这里upload_to的值是连接在MEDIA_ROOT/路径后的一部分,所以很自然的只能写成avatar/或者./avatar/,而不能写成/avatar/,楼主已经以身试法过。

还有一点,这里提到了MEDIA_ROOT,可是我们一直没设置过啊。

headImg = models.FileField(upload_to='avatar/')

所以理所当然的要设置MEDIA_ROOT,所以在settings.py中做如下设置,这里的意思就是说,我们在项目根目录下会新建一个media文件夹,专门用来存放media文件。结合上面的设置可推出,我们上传的文件会放在/media/avatar/下:

MEDIA_ROOT = os.path.join(BASE_DIR, 'media').replace("\\", "/")```

这`MEDIA_ROOT`就是媒体根目录的路径,这……好像是废话。上传的文件也会放在这里,但是正如我们上面探索时提到的:使用文件,实质上也是调用了一个文件的url,在Django中提到url,都是要从`urlpatterns`中过滤一遍的。

所以,展示图片的逻辑应该是这样的:我们调用图片的url一般是有规律的,我们过滤的时候发现,只要符合,就按照文件名从媒体根目录中找相应的文件。

- 所以,我们先找到图片url的规律,都说了,图片都是存在`/media/avatar/`中,也就是说图片的路径应该是包含`/media/avatar/`的,为了保险起见以及后续我们可能会存除了头像之外的其他文件,比如储存缩略图的叫`/media/thumb/`,所以这里我们取大家共有的`/media/`作为过滤url的规律。

MEDIA_URL = '/media/'

- 这也就是为什么`MEDIA_ROOT`和`MEDIA_ROOT`经常一起出现,并且他们的有相同的值。

准备好这些后,在`urlpatterns`中写吧,这里写的路由和普通的路由不一样,因为我们这里的所有的媒体文件其实都是静态文件的一部分,而且我们一般路由符合条件后是去执行`views`中的某个函数,这里却是去某个文件夹中找文件,所以肯定写法上是不同的,写法是`static(如果符合这样规律的url,就去这个目录中找文件)`:

导入这两个包

setting.py中

from django.conf import settings
from django.conf.urls.static import static

urlpatterns = [
...
] + static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT)```

如果你之前在探索的时候经常会看看浏览器会输出什么错误,你一般都是看到要么是404 error,要么就是500 error。为什么会出现404 error,就是因为我们给的图片路径没有在urlpatterns中定义过,所以Django在要展示图片的时候,一看,咦,这什么鬼url,在urlpatterns中根本没有对应的可以查,所以是错误的请求网址,返回404 error。在urlpatterns中添加之后,就不会有404 error了。

好了,我们还剩下最后一步,就是在img的src中填写正确的图片地址。我们之前说了图片是储存在/media/avatar/下面的,所以图片的路径就是:

<img src="/media/{{user.headImg}}" alt=""/>

因为我们储存在数据库中的图片路径是upload_to的值和图片名称的拼接,比如下面的avatar/test_mini.jpg。

补充知识:解决django的html无法加载图片的问题

html的代码都是对的

但是django网页加载不出图片

django 读取图片到页面实例

这里来给大家演示一下,因为setting.py少了东西,无法查找图片路径

django 读取图片到页面实例

STATICFILES_DIRS=(
 os.path.join(BASE_DIR,'static'),
)

补上这个代码

django 读取图片到页面实例

html插入图片很简单,我这里就举个栗子

{% load static %} <body background="{% static 'imges/bg.png' %}"></body>

运行一下

django 读取图片到页面实例

ok, nice!

以上这篇django 读取图片到页面实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python实现遍历数据库并获取key的值
May 17 Python
黑科技 Python脚本帮你找出微信上删除你好友的人
Jan 07 Python
centos6.4下python3.6.1安装教程
Jul 21 Python
python爬虫实战之最简单的网页爬虫教程
Aug 13 Python
python利用urllib和urllib2访问http的GET/POST详解
Sep 27 Python
Python2.7基于笛卡尔积算法实现N个数组的排列组合运算示例
Nov 23 Python
分享Python切分字符串的一个不错方法
Dec 14 Python
python实现读取excel文件中所有sheet操作示例
Aug 09 Python
使用celery和Django处理异步任务的流程分析
Feb 19 Python
python爬虫开发之使用python爬虫库requests,urllib与今日头条搜索功能爬取搜索内容实例
Mar 10 Python
基于python爬取有道翻译过程图解
Mar 31 Python
Python selenium模拟手动操作实现无人值守刷积分功能
May 13 Python
django ListView的使用 ListView中获取url中的参数值方式
Mar 27 #Python
django列表筛选功能的实现代码
Mar 27 #Python
python实现猜数游戏
Mar 27 #Python
手把手教你安装Windows版本的Tensorflow
Mar 26 #Python
python pandas.DataFrame.loc函数使用详解
Mar 26 #Python
Python计算指定日期是今年的第几天(三种方法)
Mar 26 #Python
Python函数默认参数常见问题及解决方案
Mar 26 #Python
You might like
15种PHP Encoder的比较
2007/03/06 PHP
php获取用户浏览器版本的方法
2015/01/03 PHP
学习面向对象之面向对象的基本概念:对象和其他基本要素
2010/11/30 Javascript
JS 如果改变span标签的是否隐藏属性
2011/10/06 Javascript
JavaScript面向对象设计二 构造函数模式
2011/12/20 Javascript
JQuery实现倒计时按钮具体方法
2013/11/14 Javascript
jquery常用方法及使用示例汇总
2014/11/08 Javascript
Javascript中arguments和arguments.callee的区别浅析
2015/04/24 Javascript
javascript带回调函数的异步脚本载入方法实例分析
2015/07/02 Javascript
jQuery检测返回值的数据类型
2015/07/13 Javascript
javascript解析xml实现省市县三级联动的方法
2015/07/25 Javascript
javascript日期比较方法实例分析
2016/06/17 Javascript
vue之数据交互实例代码
2017/06/20 Javascript
JavaScript算法教程之sku(库存量单位)详解
2017/06/29 Javascript
百度地图去掉marker覆盖物或者去掉maker的label文字方法
2018/01/26 Javascript
vue使用svg文件补充-svg放大缩小操作(使用d3.js)
2020/09/22 Javascript
python mysqldb连接数据库
2009/03/16 Python
python中二维阵列的变换实例
2014/10/09 Python
python内存管理分析
2015/04/08 Python
详解Python中的变量及其命名和打印
2016/03/11 Python
Python运行报错UnicodeDecodeError的解决方法
2016/06/07 Python
python中 chr unichr ord函数的实例详解
2017/08/06 Python
Python实现的多进程拷贝文件并显示百分比功能示例
2019/04/09 Python
基于Python的自媒体小助手---登录页面的实现代码
2020/06/29 Python
Python爬虫模拟登陆哔哩哔哩(bilibili)并突破点选验证码功能
2020/12/21 Python
韩国知名的家庭购物网站:CJmall
2016/08/01 全球购物
Richards网上商店:当代时尚,遍布巴西
2019/11/03 全球购物
Jones New York官网:美国女装品牌,受白领女性欢迎
2019/11/26 全球购物
某个公司的Java笔面试题
2016/03/11 面试题
日语求职信范文
2013/12/17 职场文书
学生生病请假条范文
2014/02/16 职场文书
客运企业隐患排查工作方案
2014/06/06 职场文书
三月法制宣传月活动总结
2014/07/03 职场文书
商场父亲节活动方案
2014/08/27 职场文书
幼儿园教师安全责任书
2015/05/08 职场文书
2016秋季运动会前导词
2015/11/25 职场文书