在models.py中添加image模型:

class Image(models.Model):

user=models.ForeignKey(settings.AUTH_USER_MODEL,related_name='image_created')

title=models.CharField(max_length=200)

url=models.URLField()

image=models.ImageField(upload_to='images/%Y/%m/%d')

descriptions=models.TextField(blank=True)

created=models.DateTimeField(default=timezone.now)

user_like=models.ManyToManyField(settings.AUTH_USER_MODEL,related_name="image_liked",blank=True)

def __str__(self):

return self.title

1 user:标记了这张图片 User 对象。这是一个 ForeignKey字段,因为它指定了一个一对多关系: 一个用户可以 post 多张图片, 但是每张图片只能由一个用户上传

2 user_like: 当你定义一个ManyToMany字段时,Django 会用两张表主键(primary key)创建一个中介联接表。ManyToMany字段可以在任意两个相关联的表中创建。同ForeignKey字段一样,ManyToMany字段的related_name属性使我们可以命名另模型回溯(或者是反查)到本模型对象的关系。ManyToMany字段提供了一个多对多管理器(manager),这个管理器使我们可以回溯相关联的对象比如:image.users_like.all()或者从一个user中回溯,比如:user.images_liked.all()。

3 models.ImageField(upload_to='images/%Y/%m/%d')制定了图片上传的路径。

同步数据库:

zhf@zhf-maple:~/py_prj/mysite$ python manage.py makemigrations

Migrations for 'blog':

blog/migrations/0006_image.py

- Create model Image

zhf@zhf-maple:~/py_prj/mysite$ python manage.py migrate

Operations to perform:

Apply all migrations: admin, auth, blog, contenttypes, sessions, taggit

Running migrations:

Applying blog.0006_image... OK

在forms.py中定义ImageCreateForm提交图片的表单

class ImageCreateForm(forms.ModelForm):

class Meta:

model=Image

fields=('title','url','descriptions')

widgets={'url':forms.HiddenInput,}

def clean_url(self):

url=self.cleaned_data['url']

valid_extensions=['jpg','jpeg']

extensions=url.rsplit('.',1)[1].lower()

if extensions not in valid_extensions:

raise forms.ValidationError('The given url does not match valid image extensions')

return url

为了验证提供的图片 URL 是否合法,我们将检查以.jpg或.jpeg结尾的文件名,来只允许JPG文件的上传。Django允许你自定义表单方法来清洁特定的字段,通过使用以clean_<fieldname>形式命名的方法来实现。这个方法会在你为一个表单实例执行is_valid()时执行。在清洁方法中,你可以改变字段的值或者为某个特定的字段抛出错误当需要的时候,将下面这个方法添加进ImageCreateForm。

clean_url: 从表单实例的cleaned_data字典中获取url字段的值

extensions:通过分类URL来获取文件扩展名,然后检查它是否为合法扩展名之一,如果不是合法的扩展名,就会抛出ValidationError异常

在ImageCreateForm中重写save函数。

def save(self, force_insert=False,force_update=False,commit=True):

image=super(ImageCreateForm,self).save(commit=False)

image_url=self.cleaned_data['url']

image_name=self.title

response=request.urlopen(image_url)

image.image.save(image_name,ContentFile(response.read()),save=False)

if commit:

image.save()

return image

上面的这段代码:

1 调用save()方法从表单中新建了一个image对象,并且commit=False

2 从表单的cleaned_data字典中获取了 URL

3 生成图片的名字

4使用 Python 的 urllib3 模块来下载图片,然后我们调用save()方法把图片传递给一个ContentFile对象,这个对象被下载的文件所实例化。这样,我们就可以将我们的文件保存到项目中的 media 路径下。我们传递了参数comiit=False来避免对象被保存到数据库中。

4 为了保持和我们覆写的save()方法一样的行为,我们将在commit参数为Ture时保存表单到数据库中

接下来需要在views.py中添加一个新的视图来控制我们的表单,编辑views.py文件,然后添加image_create方法:

@login_required(login_url='/account/login')

def image_create(request):

if request.method=='POST':

form=ImageCreateForm(data=request.POST)

if form.is_valid():

cd=form.cleaned_data

new_item=form.save(commit=False)

new_item.user=request.user

new_item.save()

messages.success(request,'image added successfully')

return redirect(new_item.url)

else:

form=ImageCreateForm(data=request.GET)

return render(request,'blog/create.html',{'section':'images','form':form})

1 image_create添加了login_required装饰器来判断是否有用户登录

2 new_item.user=request.user进行用户和图片的绑定,这样就知道了是谁上传的这个图片

3 然后将image对象保存到了数据库中

在blog应用的urls.py中添加路由:

url(r'^create/$',views.image_create,name='create')

在主应用的urls.py中添加路由:

url(r'^image/',include('blog.urls'))

在templates/blog下添加create.html。代码如下:

{% extends "blog/base.html" %}

{% block title %}给图片加标签{% endblock %}

{% block content %}

<h1>给图片加标签</h1>

<img src="{{ request.GET.url }}" class="image-preview">

<form action="." method="post">

{{ form.as_p }}

{% csrf_token %}

<input type="submit" value="Bookmark it!">

</form>

{% endblock %}

在浏览器中输入http://127.0.0.1:8000/image/create/?title=picture&url=http://upload.wikimedia.org/wikipedia/commons/8/85/Django_Reinhardt_and_Duke_Ellington_(Gottlieb).jpg

得到的效果如下:

点击Bookmark it后图片上传成功,进入后台后可以查看到上传的图片信息,其中包括上传路径,上传的用户

Django之博客系统:在网站中分享内容(一)的更多相关文章

  1. Django(博客系统):基于pycharm如何一个django工程下创建多个app

    背景:通常我们创建一个django系统时,为了把业务模块划分清楚往往会把一个独立的业务模块放到一个app中,如果多个独立的业务模块就会创建多个app,一般情况下为了更好的管理这些app,会把他们都存放 ...

  2. Django练习——博客系统小试

    在上一篇博客Todolist的基础上(http://blog.csdn.net/hcx25909/article/details/24251427),本周继续进行实践,这次我要搭建一个简单的博客系统. ...

  3. 纯django开发博客系统

    企业级教程:纯django开发博客系统 1.视频教程 https://www.duanshuilu.com/ 2.教程文档 https://www.duanshuilu.com/ 0.课程简介1.简价 ...

  4. 【django之博客系统开发】

    一.项目简介 使用django开发一套博客系统,参考博客园. 需求如下: 项目结构: 二.全部代码 from django.db import models # Create your models ...

  5. Django之博客系统邮件分享博客

    在上一章中,我们创建了一个基础的博客应用,我们能在http://127.0.0.1:8000/blog/显示我们的博客.在这一章我们将尝试给博客系统添加一些高级的特性,比如通过email来分享帖子,添 ...

  6. Django之博客系统搭建一

    前面已经介绍了django的各种用法,从这一章开始,将实际搭建一个blog系统. 首先我们需要设计blog的模型,在models.py中添加如下内容 # -*- coding: utf-8 -*- f ...

  7. Django之博客系统:用户登陆

    使用django有一个好处就是有各种各样的框架可以拿来直接使用.相比flask,django自带的框架确实要多很多.比如这一章就要介绍的用户登录.Django拥有一个内置的认证(authenticat ...

  8. Django之博客系统:增加评论

    3既然是博客,那肯定就有留言评论系统.在这一章就来建立一个评论系统. 1 创建一个模型来保存评论 2 创建一个表单来提交评论并且验证输入的数据 3 添加一个视图函数来处理表单和保存新的评论到数据库 4 ...

  9. Django之博客系统:自定义模板标签

    Django提供了很多内置的模板标签比如{% if %}或者{% block %}Django也允许你创建自己的模板标签(template tags)来执行自定义的动作.当你需要在你的模板中添加功能而 ...

  10. Django之博客系统:增加标签

    一般在发表博客后会给每个帖子加上一个标签.类似帖子关键字的功能.在这一章中来看下如何给博客添加标签功能(tagging) 添加标签需要集成第三方的Django标签应用来完成这个功能.django-ta ...

随机推荐

  1. 创建Task的多种方法

    Gradle的Project从本质上说只是含有多个Task的容器,一个Task与Ant的Target相似,表示一个逻辑上的执行单元. 我们可以通过多种方式定义Task,所有的Task都存放在Proje ...

  2. 最小LINUX系统下U盘的挂载及卸载

    U盘挂载命令U盘插入的时候会显示启动信息,启动信息中sda: sda1指U盘的设备名为sda1dev设备目录下有一个sda1设备文件,此设备文件就是我们插入的U盘,我们将这个设备文件挂载到Linux系 ...

  3. Python:序列的copy() 方法和 copy 模块

    转于:Python中copy和deepcopy中的区别 博主:assan 一.序列中的 copy() 方法 # 此方法为浅度复制:复制的数会随着被复制数的嵌套序列的元素的改变而改变: # 功能:将一个 ...

  4. declare handler 声明异常处理的语法

    声明异常处理的语法 DECLARE {EXIT | CONTINUE} HANDLER FOR {error-number | SQLSTATE error-string | condition} S ...

  5. linux命令 把Windows 文件拷贝到linux

    scp build.zip mesadmin@dpydalapp01.sl.bluecloud.ibm.com:/tmp   // 把Windows上的build.zip拷贝到mesadmin@dpy ...

  6. 基于OpenCV的火焰检测(一)——图像预处理

    博主最近在做一个基于OpenCV的火焰检测的项目,不仅可以检测图片中的火焰,还可以检测视频中的火焰,最后在视频检测的基础上推广到摄像头实时检测.在做这个项目的时候,博主参考了很多相关的文献,用了很多种 ...

  7. 获取Linux权限后安装rootkit

    1.首先获得远程服务器的root权限,当然这是基本的也是最难的. 2.然后下载rootkit程序,本文用到的是mafix. 3.开始安装 wget http://godpock.googlecode. ...

  8. chrome开发者工具的使用

    转自:https://blog.csdn.net/csdnligao/article/details/53925094

  9. java.lang.ClassNotFoundException: org.apache.commons.fileupload.FileItemFactory报错springmvc

    转自:https://blog.csdn.net/qq_41879385/article/details/82892555 下面是错误信息:java.lang.ClassNotFoundExcepti ...

  10. 【摘自张宴的"实战:Nginx"】nginx配置

    user nobody;worker_processes 2; #error_log logs/error.log;error_log logs/error.log notice;#error_log ...