django 读取图片到页面实例

作者:zhangyu4863 时间:2023-02-22 13:30:50 

首先,我们看看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了。

来源:https://blog.csdn.net/zhangyu4863/article/details/81050988

标签:django,读取,图片,页面
0
投稿

猜你喜欢

  • ASP中使用Session变量的优缺点

    2007-10-01 18:02:00
  • python 中的np.zeros()和np.ones()函数详解

    2023-01-14 10:23:58
  • Python判断变量名是否合法的方法示例

    2022-07-31 19:05:12
  • 关于python下cv.waitKey无响应的原因及解决方法

    2022-03-04 14:51:21
  • 再谈 Web 默认字体

    2009-11-24 12:48:00
  • 以Python代码实例展示kNN算法的实际运用

    2024-05-22 10:28:42
  • 内联格式化模式(line-height原理)

    2008-06-29 14:37:00
  • 基于Python写一个番茄钟小工具

    2023-05-02 07:53:37
  • JS target与currentTarget区别说明

    2023-08-22 20:14:40
  • Oracle批量查询、删除、更新使用BULK COLLECT提高效率

    2023-07-14 03:15:52
  • 微信小程序开发工具介绍

    2023-08-10 23:05:40
  • php之app消息推送案例教程

    2023-06-15 00:42:02
  • Python序列对象与String类型内置方法详解

    2023-09-22 13:25:18
  • js控制文本框输入的字符类型方法汇总

    2024-04-10 13:57:03
  • js操作IE浏览器弹出浏览文件夹可以返回目录路径

    2024-04-16 09:50:39
  • 转换字符串单词的第一个字母为大写

    2007-10-18 10:50:00
  • python如何通过闭包实现计算器的功能

    2023-10-04 06:08:06
  • TypeScript入门-基本数据类型

    2024-06-07 15:56:50
  • 基于Python实现人脸识别和焦点人物检测功能

    2021-03-09 10:27:45
  • Windows安装Anaconda3的方法及使用过程详解

    2022-03-03 06:20:10
  • asp之家 网络编程 m.aspxhome.com