该博客开发基于python2.7.13 、django 1.11.18 开发,如版本不一致,开发过程中使用的类库请与本身环境保持一致!
项目源码下载:http://download.vhosts.cn
1. 新建项目 文件 ------> 新项目---->django
填上自己的博客项目名称,并新建虚拟开发环境。(虚拟开发环境可保障每个项目之间的依赖类库环境互相独立)
2. 新建apps(用于存放自己的项目模块) 和extra_apps(用于存放第三方项目模块) 两个python package包,并将这两个包设置成django查找根目录
3. 创建静态资源(static)、多媒体(media)、日志(logs) 三个目录和自定义配置文件(config)包(config 是个包,后面需要引入它的模块变量)
4. 在static目录中创建js 、 css 、img 三个目录分别存放各自对应的前端静态文件
5. 在media 目录中创建images 、 files、 video 三个目录分别存放自己上传的对应文件
完成上述步骤后,项目初步结构如下:
项目源码下载:http://download.vhosts.cn
xadmin 下载地址:https://github.com/sshwsfc/xadmin或 https://github.com/search?q=xadmin 查找自己想要的xadmin版本
1. 下载xadmin源码包到extra_apps 包中解压, 解压后找到requirements.txt 文件,该文件写明了该版本xadmin所需的依赖包,逐步安装依赖包,依赖包版本匹配文件中指定版本。
2. 安装xadmin 依赖包:
文件——>设置——>项目——>Project Interpreter #选中项目指定的虚拟开发环境
修改默认pycharm 安装源为豆瓣源(默认使用安装源非常慢,可改用豆瓣或阿里,首选豆瓣源)
依赖包安装完成后,如下:
安装完成后将xadmin-master 中的xadmin 目录移动到extra_apps 目录下,解压文件夹(xadmin-master) 和压缩包都可以删除,接下来只需要使用xadmin 模块即可。
项目源码下载:http://download.vhosts.cn
Ueditor 是一块百度出的富文本编辑器,本身没有python 版本(只有java php 和 js)。此处使用第三方封装的DjangoUeditor
https://github.com/zhangfisher/DjangoUeditor 或者 https://github.com/search?q=djangoueditor 查找自己想要的版本。
1. 下载 djangoueditor 到extra_apps 中解压,并将解压后的djangoueditor-master中的DjangoUeditor 文件夹移动到extra_apps 目录下,解压文件夹(DjangoUeitor-master) 和 压缩包都可以删除
2.安装完成后,结构如下图:
项目源码下载:http://download.vhosts.cn
思考:
博客主要用于文章、图片、视频等资讯内容发布, 既然是发布类站点,首先得有发布的内容,然后需要有人对其进行管理,还需要可以评论,如果后期有会员机制还需要有登录和用户中心等。所以基本可以分为两大类,一类为发布内容,一类为用户管理。
有了数据表结构逻辑之后,可以区分apps 模块为两个,一个users 一个 blogs
users 模块两张表:userprofile 用户表和emailverifycode用户注册表
blogs 模块4张表: artical 文章表、tags文章标签表、catagroy文章分类表和comments文章评论表
有了上述思考和归纳,就可以新建我们的users 、blogs两个app。
在项目根目录下执行如下命令:
新建完成后,将两个app 移动到apps 包中
一、创建app models
vim apps\users\models.py
# -*- coding: utf-8 -*- from __future__ import unicode_literals from django.contrib.auth.models import AbstractUser from django.db import models # Create your models here. class UserProfile(AbstractUser): ''' 用户表 :param id 自动生成 username 和 password 都继承AbstractUser表 blank = True 针对表单提交,提交时可以为空 auto_now 不管是创建还是修改都会更新该字段 auto_now_add 只有在创建时会更新字段,修改时保持不变 ''' USERNAME_FIELD = "username" GENDER_CHOISE = (('M', u'男'), ('F', '女')) gender = models.CharField(verbose_name='性别', choices=GENDER_CHOISE, max_length=1, default='M') mobile = models.CharField(verbose_name='手机号码', max_length=11, null=True, blank=True) photo = models.ImageField(verbose_name='头像', upload_to='images', max_length=100, default='images/default.jpg') updatetime = models.DateTimeField(verbose_name='更新时间', auto_now=True) createtime = models.DateTimeField(verbose_name='创建时间', auto_now_add=True) class Meta: app_label = 'users' verbose_name = u'用户' verbose_name_plural = verbose_name db_table = 'user_profile' ordering = ['-updatetime'] def __unicode__(self): return self.username class EmailVerifyRecode(models.Model): TYPE_CHOICES = ( ('register', u'注册'), ('forget', u'找回密码') ) code = models.CharField(verbose_name='验证码', max_length=20) email = models.EmailField(verbose_name='邮箱', max_length=50) sendtype = models.CharField(verbose_name='验证码类型', max_length=20, choices=TYPE_CHOICES) updatetime = models.DateTimeField(verbose_name='更新时间', auto_now=True) createtime = models.DateTimeField(verbose_name='创建时间', auto_now_add=True) class Meta: app_label = 'users' verbose_name = '邮箱验证码' verbose_name_plural = verbose_name db_table = 'email_verify_recode' def __unicode__(self): return self.code
vim apps\blogs\models.py
# -*- coding: utf-8 -*- from __future__ import unicode_literals from django.db import models from DjangoUeditor.models import UEditorField # Create your models here. class Catagroy(models.Model): ''' 文章分类 ''' name = models.CharField(verbose_name='分类名', max_length=30) parent = models.CharField(verbose_name='归属于', max_length=30, null=True, blank=True) updatetime = models.DateTimeField(verbose_name='修改时间', auto_now=True) createtime = models.DateTimeField(verbose_name='创建时间', auto_now_add=True) class Meta: verbose_name = u'文章分类' verbose_name_plural = verbose_name db_table = 'catagory' ordering = ['createtime'] def __unicode__(self): return '{} | {}'.format(self.name, self.parent) class Tags(models.Model): ''' 文章标签 ''' name = models.CharField(verbose_name='标签名', max_length=30) updatetime = models.DateTimeField(verbose_name='修改时间', auto_now=True) createtime = models.DateTimeField(verbose_name='创建时间', auto_now_add=True) class Meta: verbose_name = u'文章标签' verbose_name_plural = verbose_name db_table = 'tags' ordering = ['-updatetime'] def __unicode__(self): return self.name class Artical(models.Model): ''' 文章表 :param ''' title = models.CharField(verbose_name='标题', max_length=50) author = models.CharField(verbose_name='作者', max_length=50) content = UEditorField(verbose_name=u'文章正文', width=850, height=500, toolbars="full", imagePath="images/", filePath="files/", upload_settings={"imageMaxSize": 51200000, "videoPath": "video/"}, settings={}, command=None, blank=True) click_num = models.IntegerField(verbose_name='点击率', default=0) catagroy = models.ForeignKey(Catagroy) tags = models.ManyToManyField(Tags) updatetime = models.DateTimeField(verbose_name='修改时间', auto_now=True) createtime = models.DateTimeField(verbose_name='创建时间', auto_now_add=True) class Meta: verbose_name = u'文章' verbose_name_plural = verbose_name db_table = 'artical' ordering = ['createtime'] def __unicode__(self): return '{} | {}'.format(self.title, self.catagroy) class Comments(models.Model): ''' 评论 ''' username = models.CharField(verbose_name='昵称', max_length=16, null=True, blank=True) email = models.EmailField(verbose_name='邮箱') content = models.CharField(verbose_name='评论内容', max_length=500) artical = models.ForeignKey(Artical, verbose_name='博客文章') updatetime = models.DateTimeField(verbose_name='修改时间', auto_now=True) createtime = models.DateTimeField(verbose_name='发布时间', auto_now_add=True) class Meta: verbose_name = u'文章评论' verbose_name_plural = verbose_name db_table = 'comments' ordering = ['-updatetime'] def __unicode__(self): return self.username
二、配置路由(未区分项目模块,urls 分离到各个app,需要在app中新建urls.py文件)
2.1 配置项目主路由
vim cpyblog\cpyblog\urls.py
from django.conf.urls import url, include from django.contrib import admin import xadmin from django.conf.urls.static import static from django.conf import settings from users import urls as userurls from blogs import urls as blogurls from blogs.views import IndexView urlpatterns = [ url(r'^$', IndexView.as_view(), name='index'), url(r'^admin/', admin.site.urls), url(r'^xadmin/', xadmin.site.urls), url(r'^ueditor/', include('DjangoUeditor.urls')), url(r'^users/', include(userurls)), url(r'^blogs/', include(blogurls)), ] + static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT) + static(settings.STATIC_URL, document_root=settings.STATIC_ROOT)
2.2 配置users app 路由
vim cpyblog\apps\users\urls.py
#!/usr/bin/env python # -*- coding:utf-8 -*- __author__ = 'cpy' from django.conf.urls import url urlpatterns = [ ]
2.3 配置cpyblog\apps\blogs\urls.py
#!/usr/bin/env python # -*- coding: utf-8 -*- from django.conf.urls import url urlpatterns = [ ]