用Django搭建个人博客—(3)
今日主题
定义博客文章和评论的的数据库定义
定义操作这几个Model的后台数据
User表
USER_STATUS = (
('active', u'激活'),
('suspended', u'禁用'),
('deleted', u'注销'),
)
class Users(models.Model):
username = models.CharField(u'用户名', unique=True, max_length=20)
password = models.CharField(u'密码', max_length=128)
nickname = models.CharField(u'昵称', max_length=50, blank=True)
avatar = models.ImageField(u'头像', upload_to='avatar/%Y/%m', max_length=100, blank=True, null=True)
display = models.CharField(u'显示名', max_length=100, blank=True)
email = models.EmailField(u'邮箱', max_length=255, blank=True)
url = models.URLField(u'个人主页', max_length=255, blank=True)
created_at = models.DateTimeField(u'创建时间', auto_now_add=True)
activation_key = models.CharField(u'激活码', max_length=60, blank=True)
status = models.CharField(u'状态', max_length=10, default='active', choices=USER_STATUS)
这里简单说明一点点,Django里面很少用到纯粹的sql.基本上都是用Django封装的orm来干这些事情.
SQL里面的数据字段的类型在Django里面也一一对应了的,上面的User模型定义里面的CharField,IntegerField,DateTimeField等分别对应了SQL里面的字符型,整型和日期型的数据格式,
EmailField,URLField等则是Django扩展出来的字段,实际上也相当于char型的字段(多了些特定的限制而已)
扩展阅读
这一部分应该来说是比较基础也比较重要的,务必应当熟悉各个字段的使用以及相应的属性.
当然,如果有SQL基础,那更是驾轻就熟.
这里还有一点需要提醒注意的是,avatar字段使用了ImageField,并且在其属性中给定了upload_to字段.那么我们在settings.py中就需要额外的为之设定一个图片存储路径.这样图片在上传的时候就会从
settings查找MEDIA_ROOT,并将图片至于其中, 可能细心的你还注意到了在设定upload_to字段的值上面
是 avatar/%Y/%m 这样最终生成的图片路径就应该是这样的 /path/to/upload/avatar/2015/01/xx.jpg
(假设选定了一张名为xx.jpg作为头像上传了).
# settings.py
# 设定图片上传路径
MEDIA_ROOT = os.path.join(BASE_DIR, 'upload')
if not os.path.exists(MEDIA_ROOT):
os.mkdir(MEDIA_ROOT)
Posts表
def _make_uuid():
return str(uuid.uuid4()).replace('-', '').lower()
POST_STATUS = (
('publish', u'发布'),
('auto-draft', u'草稿'),
('inherit', u'继承'),
)
COMMENT_STATUS = (
('open', u'公开'),
('closed', u'私密'),
)
class Posts(models.Model):
title = models.CharField(u'标题', max_length=200)
seed = models.CharField(max_length=40, default=_make_uuid)
author = models.ForeignKey('Users', to_field='username')
name = models.SlugField(u'别名', max_length=200, blank=True)
date = models.DateTimeField(auto_now_add=True)
modified = models.DateTimeField(auto_now=True)
excerpt = models.TextField(u'摘要')
content = models.TextField(u'正文')
status = models.CharField(u'发布状态', max_length=20, default='publish', choices=POST_STATUS)
comment_status = models.CharField(u'评论状态', max_length=20, default='open', choices=COMMENT_STATUS)
password = models.CharField(u'密码', max_length=20, blank=True)
comment_count = models.IntegerField(u'评论', max_length=20, default=0)
read_count = models.IntegerField(u'阅读', max_length=20, default=0)
Posts表用来存储博客的文章,心情随笔等等.所以像标题 内容 发布时间 修改时间等等的都是必不可少的
Comments表
class Comments(models.Model):
post = models.ForeignKey('Posts')
parent = models.ForeignKey('self', blank=True, null=True)
author = models.ForeignKey('Users')
author_name = models.CharField(max_length=20, blank=True)
author_email = models.CharField(max_length=255, blank=True)
author_url = models.URLField(max_length=255, blank=True)
author_IP = models.GenericIPAddressField(unpack_ipv4=True, blank=True, null=True)
date = models.DateTimeField(auto_now_add=True)
content = models.TextField()
Links表
LINK_VISIBLE = (
('Y', u'可见'),
('N', u'不可见'),
)
class links(models.Model):
owner = models.ForeignKey('users')
url = models.URLField(max_length=255)
name = models.CharField(max_length=255)
image = models.CharField(max_length=255, blank=True)
target = models.CharField(max_length=25, blank=True)
description = models.CharField(max_length=255, blank=True)
visible = models.CharField(max_length=20, default='Y', choices=LINK_VISIBLE)
date = models.DateTimeField(auto_now_add=True)
modified = models.DateTimeField(auto_now=True)
rating = models.IntegerField(default=0)
这些天有些冷,人都变得倦怠了.应该自我检讨一下了.
附带一笔记录一下今天使用Django form的一点笔记:
此处以Users为例,小叙一下通过Django自定义的表单进行数据验证
# 1
from django.forms import forms
class UserForm(forms.ModelForm):
class Meta:
model = models.Users
fields = ['username', 'password']
最简单的一个Form就这么华丽丽的完成了,
models.Users 指定模型
fields 指定必要字段
然后在后台的views中就可以直接调用这个写好的Form对数据进行验证了,当然,同样也可以利用它生成表格输入框
进一步深入, 自定义字段验证
# 1
from django.forms import forms
class UserForm(forms.ModelForm):
def __init__(self, *args, **kwargs):
# 为什么没有**kwargs, 是不是去读读源码?
super(UserForm, self).__init__(*args)
# do something with sth in kwargs
def clean(self):
# 让自带的方法帮我们验证剩余的字段
cleaned_data = super(UserForm, self).clean()
username = cleaned_data.get('username')
if 'ooxx' in username:
self._errors['username'] = u'名字太黄了,禁止注册!'
del cleaned_data['username']
pwd = cleaned_data.get('password')
if len(str(pwd)) < 4:
self._errors['password'] = u'那啥太短了,密码太短了.'
del cleaned_data['password']
# ....
return cleaned_data
class Meta:
model = models.Users
fields = ['username', 'password', 'email']
再简单的写一个后台的用户注册和编辑的views
# users.py
from django.shortcuts import RequestContext
from django.shortcuts import render_to_response
from blog import models
from blog import forms
def add(request, *args, **kwargs):
if request.method == 'POST':
form = forms.UserForm(request.POST)
if form.is_valid():
user = form.save()
return render_to_response('core/user.html', {'user': user}, context_instance=RequestContext(request))
else:
return render_to_response('core/register.html', {'form': form}, context_instance=RequestContext(request))
form = forms.UserForm()
return render_to_response('core/register.html', {'form': form}, context_instance=RequestContext(request))
def edit(request, *args, **kwargs):
username = request.POST.get('username', None)
if username:
obj = models.Users.objects.get(username=username)
form = forms.UserForm(request.POST, instance=obj)
if form.is_valid():
form.save()
return render_to_response('core/user.html', {'user': user}, context_instance=RequestContext(request))
return render_to_response('core/edit.html', {'form': form}, context_instance=RequestContext(request))
用Django搭建个人博客—(3)的更多相关文章
- Django搭建简易博客
Django简易博客,主要实现了以下功能 连接数据库 创建超级用户与后台管理 利用django-admin-bootstrap美化界面 template,view与动态URL 多说评论功能 Markd ...
- python关于Django搭建简单博客项目(详解一)
上一篇我们说了如何搭建简易博客网站,下面我们来进行详细解答.本文没有特定顺序,请结合上一篇和源代码参照学习. 相关源代码和解析请参看:https://github.com/Cheng0829/mysi ...
- 用Django搭建个人博客—(1)
业精于勤荒于嬉,形成于思毁于随. 本阶段的任务小记: 简单介绍一下Django的使用,创建项目和一个app 简单介绍一下Django的settings.py文件的相关配置 整合数据库到自己的博客系统中 ...
- python关于Django搭建简单博客项目(教程)
由于csdn各种django blog博文都有或多或少的bug,所以我决定自己写一篇,先附上教程,详解在另一篇博文里,为了便于大家复制粘贴,本文代码尽量不使用图片. 源代码及解析文章请在我的githu ...
- Django 搭建简易博客
新增一个 APP 博客算是一个功能集,因此我们应将其体现为一个模块.这表现在 Django 应用里则是为其创建一个 APP Package.现在让 manage.py 中的 startapp 闪亮登场 ...
- 用Django搭建个人博客—(2)
今日任务: 1 blog的数据库模型定义 2 简单的注册登录功能的实现 项目的源文件已经推送到git@oschina.net. 所以,如果想要参阅源码的请移步 (Fork) http://git.os ...
- Django搭建简易博客教程(四)-Models
原文链接: http://www.jianshu.com/p/dbc4193b4f95 Django Model 每一个Django Model都继承自django.db.models.Model 在 ...
- python关于Django搭建简单博客项目 详解二-setting.py
这一篇我们来讲解setting.py,具体内容以注释形式写入到下面的setting.py代码中,篇幅所限已把官方所给英文注释删除. 全部源代码和详解请参看http://github.com/Cheng ...
- 基于django的个人博客网站建立(一)
基于django的个人博客网站建立(一) 前言 网站效果可点击这里访问 之前基于hexo和github page搭建过一个博客网页,后来由于换了个系统,感觉弄的有点麻烦也就没有再去管它了,最近偶然从网 ...
随机推荐
- C++ 让控制台运行到最后按下回车键才结束的3种方法
初学C++,弄懂了3种在控制台最后需要按回车键才退出返回编辑框的方法 1.最简单的编译生成后,通过Ctrl+F5运行即可(推荐自己调试的时候用,因为程序在别人那里是一闪而过的) 2.先添加头文件“#i ...
- PowerMock注解PowerMockIgnore的使用方法
故事要从一个异常开始,某天我在开发一个加密.解密特性,算法使用的是3DES,样例代码如下. package org.jackie.study.powermock; import java.io.Uns ...
- [Javascript + rxjs] Using the map method with Observable
Like an array, Observable has a map method that allows us to transform a sequence into a new Observa ...
- Messages的例子
13.33 13.36 13.37 Message.h #ifndef MESSAGE_H #define MESSAGE_H #include<iostream> #include< ...
- android开发之重写Application类
在android应用开发中,重写Application也算是比较常见的,以前开发的一些程序太过于简单,都不要重写这个类,但是在真正的商业开发中,重写Application类几乎是必做的. 为什么要重写 ...
- SQL排序 空值的后面
按sort排序,sort为空的在后面 end),sort
- mRemote配置
配置完mRemote后 备份C:\Users\Administrator\AppData\Local\Felix_Deimel\mRemote\confCons.xml文件 覆盖到其他电脑可以直接使用
- Entity Framework Demo(一) 简单搭建环境
Entity Framwork(实体框架,简称EF)是ORM(Object Relational Mapping,对象映射关系)的一个解决方案. EF允许项目将数据库的表映射为实体,并封装了操作方法, ...
- PLSQL Developer操作
1.设置 1)下载32位Oracle InstantClient 2)将Oracle InstantClient解压到某目录 3)设置环境变量(修改NLS_LANG和TNS_ADMIN环境变量)对 ...
- Codeforces Round #310 (Div. 2)--B
http://codeforces.com/problemset/problem/556/B 题意:给定n个数字且都小于n,然后每次循环第2k+1个数字+1,第2k个数字减一,k=0,1,2...n/ ...