解决django的template中如果无法引用MEDIA_URL问题


Posted in Python onApril 07, 2020

配置如下

TEMPLATES = [

下面

'context_processors': [

中添加

'django.core.context_processors.media',

会把MEDIA_URL 配置在template中

这样在template下面 就可以引用MEDIA_URL了

补充知识:在django中使用 MEDIA_URL 和 MEDIA_ROOT

在django上传图片前端使用动态的配置方法

MEDIA_ROOT 代表着 要上传的路径会和你在models中写的上传的路径进行拼节形成最终文件上传的路径 

MEDIA_URL主要就是映射了 在前端使用media_url当你的media_root发生改变的时候不用去更改前端模板中的内容

前端模板中的写法

后面是从数据库中 查询出来的 上传文件的地址url

"{{ MEDIA_URL }}{{ course_org.image }}"

前端生成的路径

"/media/org/2017/07/qhdx-logo.png"/

要想正常的显示图片 还需要下面几步:

1 在settings 中配置路径

MEDIA_URL = '/media/'
MEDIA_ROOT = os.path.join(BASE_DIR, 'media')

2 在TEMPLATES 中添加一个上下文环境 'django.core.context_processors.media', 这个会

自动的把MEDIA_URL 注册到前端的模板中的 没有这个上下文环境 MEDIA_URL在前端是没有显示的

TEMPLATES = [
  {
    'BACKEND': 'django.template.backends.django.DjangoTemplates',
    'DIRS': [os.path.join(BASE_DIR, 'templates')]
    ,
    'APP_DIRS': True,
    'OPTIONS': {
      'context_processors': [
        'django.template.context_processors.debug',
        'django.template.context_processors.request',
        'django.contrib.auth.context_processors.auth',
        'django.contrib.messages.context_processors.messages',
        'django.core.context_processors.media',
      ],
    },
  },

3 在url中配置media请求的url

首先需要导入下面的库 和在settings 中配置的 MEDIA_ROOT上传路径

from django.views.static import serve
from MxOnline.settings import MEDIA_ROOT

配置url 固定的 里面的内容不能改的

url(r'media/(?P<path>.*)$', serve, {'document_root': MEDIA_ROOT}),

以上这篇解决django的template中如果无法引用MEDIA_URL问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python用模块pytz来转换时区
Aug 19 Python
Python+微信接口实现运维报警
Aug 27 Python
Python中int()函数的用法浅析
Oct 17 Python
scrapy爬虫完整实例
Jan 25 Python
python实现多进程代码示例
Oct 31 Python
理想高通滤波实现Python opencv示例
Jan 30 Python
selenium+python截图不成功的解决方法
Jan 30 Python
将Python文件打包成.EXE可执行文件的方法
Aug 11 Python
Python实现基于socket的udp传输与接收功能详解
Nov 15 Python
Python实现队列的方法示例小结【数组,链表】
Feb 22 Python
Python grequests模块使用场景及代码实例
Aug 10 Python
Python logging模块原理解析及应用
Aug 13 Python
Django {{ MEDIA_URL }}无法显示图片的解决方式
Apr 07 #Python
Python Opencv中用compareHist函数进行直方图比较对比图片
Apr 07 #Python
python opencv实现图片缺陷检测(讲解直方图以及相关系数对比法)
Apr 07 #Python
解决django无法访问本地static文件(js,css,img)网页里js,cs都加载不了
Apr 07 #Python
Pytest框架之fixture的详细使用教程
Apr 07 #Python
4行Python代码生成图像验证码(2种)
Apr 07 #Python
Django media static外部访问Django中的图片设置教程
Apr 07 #Python
You might like
PHP遍历数组的几种方法
2012/03/22 PHP
php图片的裁剪与缩放生成符合需求的缩略图
2013/01/11 PHP
laravel 数据迁移与 Eloquent ORM的实现方法
2019/04/12 PHP
Extjs学习笔记之三 extjs form更多的表单项
2010/01/07 Javascript
js控制的遮罩层实例介绍
2013/05/29 Javascript
js和jquery中循环的退出和继续下一个循环
2014/09/03 Javascript
javascript编写贪吃蛇游戏
2015/07/07 Javascript
简单谈谈JavaScript的同步与异步
2015/12/31 Javascript
使用jQuery监听DOM元素大小变化
2016/02/24 Javascript
浏览器复制插件zeroclipboard使用指南
2016/03/26 Javascript
浅谈js中的三种继承方式及其优缺点
2016/08/10 Javascript
AngularJS  $modal弹出框实例代码
2016/08/24 Javascript
AngularJS表单验证中级篇(3)
2016/09/28 Javascript
js点击任意区域弹出层消失实现代码
2016/12/27 Javascript
微信小程序 小程序制作及动画(animation样式)详解
2017/01/06 Javascript
js实现华丽的九九乘法表效果
2017/03/29 Javascript
JavaScript中防止微信浏览器被整体拖动的方法
2017/08/25 Javascript
Bootstrap标签页(Tab)插件切换echarts不显示问题的解决
2018/07/13 Javascript
JS实现判断图片是否加载完成的方法分析
2018/07/31 Javascript
9102了,你还不会移动端真机调试吗
2019/03/25 Javascript
使vue实现jQuery调用的两种方法
2019/05/12 jQuery
javascript实现的时间格式加8小时功能示例
2019/06/13 Javascript
vue element实现表格合并行数据
2020/11/30 Vue.js
linux系统使用python获取cpu信息脚本分享
2014/01/15 Python
使用PM2+nginx部署python项目的方法示例
2018/11/07 Python
Python List cmp()知识点总结
2019/02/18 Python
详解CSS3中强大的filter(滤镜)属性
2017/06/29 HTML / CSS
介绍一下代理模式(Proxy)
2014/10/17 面试题
大学应届生求职简历的自我评价
2013/10/08 职场文书
十岁生日同学答谢词
2014/01/19 职场文书
小学三年级学生评语
2014/04/22 职场文书
校园新闻广播稿5篇
2014/10/10 职场文书
数学教师个人工作总结
2015/02/06 职场文书
股东协议书范本2016
2016/03/21 职场文书
选择比努力更重要?这是长期以来对“努力”的最大误解
2019/07/12 职场文书
5行Python代码实现一键批量扣图
2021/06/29 Python