Django之博客系统:在网站中分享内容(一)
在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之博客系统:在网站中分享内容(一)的更多相关文章
- Django(博客系统):基于pycharm如何一个django工程下创建多个app
背景:通常我们创建一个django系统时,为了把业务模块划分清楚往往会把一个独立的业务模块放到一个app中,如果多个独立的业务模块就会创建多个app,一般情况下为了更好的管理这些app,会把他们都存放 ...
- Django练习——博客系统小试
在上一篇博客Todolist的基础上(http://blog.csdn.net/hcx25909/article/details/24251427),本周继续进行实践,这次我要搭建一个简单的博客系统. ...
- 纯django开发博客系统
企业级教程:纯django开发博客系统 1.视频教程 https://www.duanshuilu.com/ 2.教程文档 https://www.duanshuilu.com/ 0.课程简介1.简价 ...
- 【django之博客系统开发】
一.项目简介 使用django开发一套博客系统,参考博客园. 需求如下: 项目结构: 二.全部代码 from django.db import models # Create your models ...
- Django之博客系统邮件分享博客
在上一章中,我们创建了一个基础的博客应用,我们能在http://127.0.0.1:8000/blog/显示我们的博客.在这一章我们将尝试给博客系统添加一些高级的特性,比如通过email来分享帖子,添 ...
- Django之博客系统搭建一
前面已经介绍了django的各种用法,从这一章开始,将实际搭建一个blog系统. 首先我们需要设计blog的模型,在models.py中添加如下内容 # -*- coding: utf-8 -*- f ...
- Django之博客系统:用户登陆
使用django有一个好处就是有各种各样的框架可以拿来直接使用.相比flask,django自带的框架确实要多很多.比如这一章就要介绍的用户登录.Django拥有一个内置的认证(authenticat ...
- Django之博客系统:增加评论
3既然是博客,那肯定就有留言评论系统.在这一章就来建立一个评论系统. 1 创建一个模型来保存评论 2 创建一个表单来提交评论并且验证输入的数据 3 添加一个视图函数来处理表单和保存新的评论到数据库 4 ...
- Django之博客系统:自定义模板标签
Django提供了很多内置的模板标签比如{% if %}或者{% block %}Django也允许你创建自己的模板标签(template tags)来执行自定义的动作.当你需要在你的模板中添加功能而 ...
- Django之博客系统:增加标签
一般在发表博客后会给每个帖子加上一个标签.类似帖子关键字的功能.在这一章中来看下如何给博客添加标签功能(tagging) 添加标签需要集成第三方的Django标签应用来完成这个功能.django-ta ...
随机推荐
- 创建Task的多种方法
Gradle的Project从本质上说只是含有多个Task的容器,一个Task与Ant的Target相似,表示一个逻辑上的执行单元. 我们可以通过多种方式定义Task,所有的Task都存放在Proje ...
- 最小LINUX系统下U盘的挂载及卸载
U盘挂载命令U盘插入的时候会显示启动信息,启动信息中sda: sda1指U盘的设备名为sda1dev设备目录下有一个sda1设备文件,此设备文件就是我们插入的U盘,我们将这个设备文件挂载到Linux系 ...
- Python:序列的copy() 方法和 copy 模块
转于:Python中copy和deepcopy中的区别 博主:assan 一.序列中的 copy() 方法 # 此方法为浅度复制:复制的数会随着被复制数的嵌套序列的元素的改变而改变: # 功能:将一个 ...
- declare handler 声明异常处理的语法
声明异常处理的语法 DECLARE {EXIT | CONTINUE} HANDLER FOR {error-number | SQLSTATE error-string | condition} S ...
- linux命令 把Windows 文件拷贝到linux
scp build.zip mesadmin@dpydalapp01.sl.bluecloud.ibm.com:/tmp // 把Windows上的build.zip拷贝到mesadmin@dpy ...
- 基于OpenCV的火焰检测(一)——图像预处理
博主最近在做一个基于OpenCV的火焰检测的项目,不仅可以检测图片中的火焰,还可以检测视频中的火焰,最后在视频检测的基础上推广到摄像头实时检测.在做这个项目的时候,博主参考了很多相关的文献,用了很多种 ...
- 获取Linux权限后安装rootkit
1.首先获得远程服务器的root权限,当然这是基本的也是最难的. 2.然后下载rootkit程序,本文用到的是mafix. 3.开始安装 wget http://godpock.googlecode. ...
- chrome开发者工具的使用
转自:https://blog.csdn.net/csdnligao/article/details/53925094
- java.lang.ClassNotFoundException: org.apache.commons.fileupload.FileItemFactory报错springmvc
转自:https://blog.csdn.net/qq_41879385/article/details/82892555 下面是错误信息:java.lang.ClassNotFoundExcepti ...
- 【摘自张宴的"实战:Nginx"】nginx配置
user nobody;worker_processes 2; #error_log logs/error.log;error_log logs/error.log notice;#error_log ...