Django 的图片上传与显示 1: FileField 方法

Python 2.7.13

Django==1.19.5

后一篇:Django 的图片上传与显示 2: ImageFiled 方法

Django 处理图片的上传与显示,主要使用 models 的两种 Field 来处理图片:

  • FieldField:优点是简单、不依赖第三方库;缺点是缺少对图片的复杂处理功能。
  • ImageField:优点是可以对图片进行更多处理,比如可以获得图片的宽和高的像素大小、可以缩小图片等;缺点是需要依赖第三方库 pillow

具体关于 FileField 和 ImageField 说明,也可以查看官方文档 FileField.
storage

0 前置条件

需要设置好静态文件配置参数,参照

Django 开发时的静态文件配置参数以及 collectstatic

1 FileField 方法

1.1 设置 models 中的属性

在 posts/models.py 中设置 FileField,属性要运行为空和 null。因为可能不上传图片。

class Post(models.Model):
    image = models.FileField(null=True, blank=True)

设置好之后需要数据迁移

$ python manage.py makemigrations
$ python manage.py migrate

在 posts/admin.py 中把 models 的 Post 这个类(数据表)注册进去。

from django.contrib import admin
from .models import Post

admin.site.register(Post)

开启服务器

$ python manage.py runserver 0.0.0.0:8080

进入后台 admin,在浏览器输入 127.0.0.1:8080/admin,新建或者增加 post,可以看图片可以上传了。

choose_file.png

图片上传以后,会直接保存在之前在参数设定中,用 MEDIA_ROOT 设置好的目录,名叫 media_cdn

1.2 forms 和 views

如果使用 form 表单验证,forms.py 的设置如下

from django import forms
from .models import Post

class PostForm(forms.ModelForm):
    class Meta:
        model = Post
        fields = [
            "image",
        ]

而对于 views 函数,如果是创建一个空的 form 用于提交。这里使用了 forms 表单验证,参数需要加入 request.FILES or None,否则会报错。

from django.shortcuts import redirect
from .models import Post

def post_create(request):
    form = PostForm(request.POST or None, request.FILES or None)
    if form.is_valid():
        instance = form.save(commit=False)
        
        instance.save()
        return redirect(reverse("detail", kwargs={"id": instance.id}))
    context = {
        "form": form,
    }
    return render(request, "post_form.html", context)

def post_detail(request, id=None):
    instance = get_object_or_404(Post, id=id)
    context = {
        "instance": instance,
    }
    return render(request, "post_detail.html", context)

对于路由而言,create 是创建表单,带变量 id 则是获得该 id 的详情。

from django.conf.urls import url

urlpatterns = [
    url(r'^create/$', "posts.views.post_create"),
    url(r'^(?P<id>\d+)/$',"posts.views.post_detail", name='detail'),
    # ...
]

1.3 Django 模板中的使用

form 提交

对于 form 的文件上传,一定要在 form 标签中使用 enctype='multipart/form-data' 属性,完整的属性设置如下:

templates/post_form.html

<form methdo='POST' action='' enctype='multipart/form-data'>
    {{ form.as_p }}
    <input type="submit" value="create post" name="">
    {% csrf_token %}
</form>

其中 action='' 表示提交到当前页面。

图片显示
templates/post_detail.html

{% if instance.image %}
    ![]({{ instance.image.url }})
{% endif %}

代码用图片显示为:

image_src_url.png

需要对传过来的表单数据 instance进行判断,存在图片再显示。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,992评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,212评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,535评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,197评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,310评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,383评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,409评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,191评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,621评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,910评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,084评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,763评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,403评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,083评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,318评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,946评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,967评论 2 351

推荐阅读更多精彩内容