上传图片实际上是 把图片存在服务器的硬盘中,将图片存储的路径存在数据库中。

1 首先要配置文件上传的路径:


1.1 建立静态文件目录

  在项目根目录下 新建一个 static文件夹,下面再建立一个media文件夹,在media中建立一个与应用名相同的文件夹

  static为静态文件目录,里面是各个引用的静态文件,包括js css  图片 等等

  static下一般分为 js  css media 等

  js css 和media 下一般都根据应用去建立多个文件夹,不同应用去自己的文件夹中找

我的目录是这样的:

我的应用模块是booktest

上传的图片都会保存到 static/media/booktest/中

1.2 配置静态路径

  到项目下的settings.py文件中,配置静态文件路径

  添加如下3个语句

 # Static files (CSS, JavaScript, Images)
# https://docs.djangoproject.com/en/1.8/howto/static-files/ STATIC_URL = '/myStatic/'
STATICFILES_DIRS = [
os.path.join(BASE_DIR,'static'),
]
MEDIA_ROOT=os.path.join(BASE_DIR,'static/media')

BASE_DIR代表整个项目的根目录

STATICFILES_DIRS = [ os.path.join(BASE_DIR,'static'), ]  代表指定根目录下的static目录是静态文件目录

MEDIA_ROOT=os.path.join(BASE_DIR,'static/media') 代表上传文件的目录是static/media

STATIC_URL = '/myStatic/' 代表 我们在编程的时候,用到静态路径的时候 用/myStatic/ 来找到静态文件的目录

2 建立一个数据库,用于存储上传的图片存在服务器的哪个路径下

在模型中建立图片的模型类并迁移

#上传图片的模型类
class Pictures(models.Model):
pic = models.ImageField(upload_to='booktest/')
def __str__(self):
return self.pic

迁移命令:

生成迁移文件: python manage.py makemigrations

执行迁移: python manage.py migrate

图片的上传:

1 用户上传图片:
1 前端的form表单input上传:

前端模板代码:

 <body>
<form action="/upload/" method="post" enctype="multipart/form-data" >
{% csrf_token %}
上传:
<input type="file" name="picture">
<input type="submit" value="上传"> </form> </body>

2 url映射部分 省略......

3 视图view的代码:

 # 上传图片
from django.conf import settings
from .models import Pictures
# 返回上传图片的页面
def getUpload(request):
return render(request,'booktest/upload.html') # 发来表单 实现上传功能
def upload(request):
# 从请求当中 获取文件对象
f1 = request.FILES.get('picture')
# 利用模型类 将图片要存放的路径存到数据库中
p = Pictures()
p.pic = "booktest/" + f1.name
p.save()
# 在之前配好的静态文件目录static/media/booktest 下 新建一个空文件
# 然后我们循环把上传的图片写入到新建文件当中
fname = settings.MEDIA_ROOT + "/booktest/" + f1.name
with open(fname,'wb') as pic:
for c in f1.chunks():
pic.write(c)
return HttpResponse("上传成功")

这个时候我们在前段上传提交后,

在静态文件夹下多了一个图片文件

数据库中插入了一条信息,存储图片存放路径。

2 管理页面上传图片

在前台申请 127.0.0.1:8000/admin登陆后 上传图片

1 首先在admin.py中注册一下上传图片的模型类

 from django.contrib import admin
from .models import Pictures
# Register your models here.
admin.site.register(Pictures)

2 登陆 xxxx:8000/admin/  登陆后 看到我们的数据库表,点开直接上传就可以。

上传之后我们就能发现 数据库多了一条数据,本地静态文件路径也多了一个图片。

创建管理账户的命令: python manage.py createsuperuser

图片的显示:


原理是从数据库中取到路径,然后再去路径找文件,返回给前台模板

views视图中的代码:

 # 显示图片
def show_pic(request):
pic_obj = Pictures.objects.get(id=1)
return render(request,'booktest/show_pic.html',{'pic_obj':pic_obj})

pic利用模型类取到id为1的图片对象,把这个图片对象送给模板

模板中代码:

 <body>
<h1>显示图片</h1> <img src="/myStatic/media/{{ pic_obj.pic }}" alt="">
</body>

pic_obj.pic: 之前建立了模型类有一个pic属性 是 ImageField类型,upload_to 指定了上传文件的目录

这里利用这个对象

django自动帮我们去静态路径下取到图片对象 放到前台。

django中图片的上传和显示的更多相关文章

  1. Django中图片的上传并显示

    一.settings配置文件中配置 MEDIA_URL = '/media/' MEDIA_ROOT = os.path.join(BASE_DIR, 'medias').replace('\\', ...

  2. MVC 4 图片的上传及显示

    1 首先我们看一下如何上传 1.1 view 上传页面: 1: @using (Html.BeginForm("Create", "Achievement", ...

  3. Django_图片的上传下载显示配置

    图片上传的配置 image = models.ImageField(upload_to='org/%Y/%m',...) upload_to默认是上传到项目的'MEDIA_ROOT/org/%Y/%m ...

  4. Django中的文件上传和原生Ajax

    概述 Django中的上传有3种方案: form 表单常规上传,但点击提交后会自动刷新页面 Ajax 上传,不刷新页面,(分为原生ajax上传和jQuery上传),IE7以上不兼容 iframe 上传 ...

  5. django中处理文件上传文件

    1 template模版文件uploadfile.html 特别注意的是,只有当request方法是POST,且发送request的<form>有属性enctype="multi ...

  6. django后台处理前端上传和显示图片

      1:项目根目录存放图片的目录 2:settings.py  添加 MEDIA_ROOT = os.path.join(BASE_DIR, "media") 3:url.py 添 ...

  7. 航空售票系统设计分析(Markdownpad2图片服务器上传无法显示)

    一.体系结构设计 1.系统原型图 2.体系结构环境图 3.构建结构图 二.人机交互界面设计 1.用户分析结果及建议 本次分析的主要目标关注用户评论反馈,对反馈进行归纳,设计出用户喜欢的界面样式.用户的 ...

  8. ruby on rails爬坑(三):图片上传及显示

    一,问题及思路 最近在用rails + react + mysql基本框架写一个cms + client的项目,里面涉及到了图片的上传及显示,下面简单说说思路,至于这个项目的配置部署,应该会在寒假结束 ...

  9. antd pro table中的文件上传

    概述 示例代码 列表页面 form 页面 model.js service.js 总结 概述 项目中经常会遇到在表格中展示图片的需求(比如展示用户信息时, 有一列是用户的头像). antd pro t ...

随机推荐

  1. video常用功能

    本文的目录: 1.获取影片总时长2.播放.暂停3.获取影片已播放时间和设置播放点4.音量的获取和设置 第一.获取影片总时长 对播放器(video)操作,首先要得到的是影片的一些信息,其中一个就是总时长 ...

  2. 在做APP前端开发时应注意的一些问题

    在做APP前端开发时应注意的一些问题 在整个app开发流程中,app前端开发是一个必不可少的环节,也是一个在app开发过程中重量级的角色.说到这,那么在app应用的前端开发中,又要注意什么问题呢?一. ...

  3. 所使用的“EntityFramework, Version=6.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089”版本高于所引用的程序集“EntityFramework, Version=5.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089”的版本

    错误信息:所使用的"EntityFramework, Version=6.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089&qu ...

  4. react-router简明学习

    前面的话 路由用来分发请求.后端是提供服务的,所以它的路由是在找controller,前端是显示页面的,所以它的路由是在找component.本文将详细介绍react-router-dom的内容 Ro ...

  5. 手写ButterKnife

    开发中使用注解框架可以极大地提高编码效率,注解框架用到的技术可以分为两种,运行时注解跟编译时注解.运行时注解一般配合反射机制使用,编译时注解则是用来生成模板代码.这里我们分别使用这两种方法实现Butt ...

  6. [HNOI2002]营业额统计_Treap

    [HNOI2002]营业额统计 题目大意:给你一串n数序列,对于每一个刚输入的数a,找到一个前面的数k,使得|a-k|最小. 注释:$n<=32767,ai<=10^6$. 想法:刚学Tr ...

  7. oracle exp(expdp)数据迁移(生产环境,进行数据对比校验)

    前言:客户需要迁移XX 库 ZJJJ用户(迁移到其他数据库),由于业务复杂,客户都弄不清楚里面有哪些业务系统,为保持数据一致性,需要停止业务软件,中间件,杀掉oracle进程. 一.迁移数据倒出部分= ...

  8. IDEA 中配置JDK

    提前安装jdk,配置环境变量 一.配置jdk 1.依次点开File -->Project Structure,点击左侧标签页,点击SDKs 2.点击+号,选SDK 3.在弹出框选择jdk路径(我 ...

  9. mui手机图片压缩上传+C#

    前台参考网址:http://www.bcty365.com/content-146-3263-1.html <html> <head> <meta charset=&qu ...

  10. Mac下安装virtualenv, 并在PyCharm中使用

    今天在安装一个leader写的package的时候,同事建议安装到虚拟环境中,再在PyCharm里使用该虚拟环境即可.此处记录下经过: 开发Python应用的时候,有时会遇到不同的Python应用依赖 ...