用django框架做自己的blog
说明:我的系统环境是ubuntu 14.10版本的,整理这篇博客,主要是自己记性太不好了,老忘东西,教训一下自己。哈哈
参考文章
createing blog
django framework application
安装django及博客相关包
apt-get install python-django -y #django version 1.7
pip install markdown pygments django-pagedown
create project
mkdir /var/www/django_project #放用django框架开发的各类应用项目
cat create_django_object.sh # 创建项目及应用脚本
#!/bin/bash
dir=/var/www/django_project
cd $dir
django-admin.py startproject $1
cd $dir/$1
python manage.py startapp $2
#使用方法如下,传两个参数: 项目名称 应用名称
./create_django_object.sh mydjblog blog
配置项目wqkblog setting.py 如下:
# Application definition
INSTALLED_APPS = (
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
#'south',
'linaro_django_pagination', #分页用
'blog',
'pagedown',
)
# 处理模板的功能
TEMPLATE_CONTEXT_PROCESSORS = (
'django.contrib.auth.context_processors.auth',
'django.core.context_processors.debug',
'django.core.context_processors.i18n',
'django.core.context_processors.media',
'django.core.context_processors.static',
'django.core.context_processors.tz',
'django.contrib.messages.context_processors.messages',
"django.core.context_processors.request"
)
# 连接数据库
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
}
}
# 设置语言
LANGUAGE_CODE = 'zh-cn'
# 时区
TIME_ZONE = 'Asia/Shanghai'
静态文件及模板目录配置
# 静态文件目录
STATICFILES_DIRS = (
os.path.join(BASE_DIR, "static"),
)
# 模版文件目录
TEMPLATE_DIRS = (
os.path.join(BASE_DIR, "templates"),
)
# 设置首页显的博客数量
PAGINATION_DEFAULT_PAGINATION = 3
# List of callables that know how to import templates from various sources.
TEMPLATE_LOADERS = (
'django.template.loaders.filesystem.Loader',
'django.template.loaders.app_directories.Loader',
)
create the models 给自己的应用创建models
说明:以python面向对象的思想将数据库表创建为类,类内部变量为字段名
# -*- coding: utf-8 -*-
from django.db import models
from django.contrib.auth.models import User
from django.core.urlresolvers import reverse
class Category(models.Model):
name = models.CharField(u'文章分类', max_length=64)
class Meta:
ordering = ['-id']
def __unicode__(self):
return self.name
@models.permalink
def get_absolute_url(self):
return ('category', (), {'pk': self.pk})
class Post(models.Model):
title = models.CharField(u"标题", max_length=128)
author = models.ForeignKey(User)
po_type = models.ForeignKey(Category, verbose_name=u'文章分类', blank=True, null=True)
#content = models.TextField(u'Content (Markdown)')
content = models.TextField(u'Content (Markdown)')
pub_data = models.DateTimeField(auto_now_add=True)
class Meta:
ordering = ["-id"]
def __unicode__(self):
return self.title
@models.permalink
def get_absolute_url(self):
return ('post', (), {'pk': self.pk})
create blog models to django admin
from django.contrib import admin
from django import forms
from pagedown.widgets import AdminPagedownWidget
from models import Post, Category
class CategoryAdmin(admin.ModelAdmin):
#prepopulated_fields = {'slug':('name',)}
list_display = ('name',)
search_fields = ('name',)
class PostFrom(forms.ModelForm):
class Meta:
model = Post
widgets = {
'content':AdminPagedownWidget(),
}
class PostAdmin(admin.ModelAdmin):
form = PostFrom
#prepopulated_fields = {'slug':('title',)}
list_display = ('title','author','po_type','content','pub_data',)
search_fields = ('title','content',)
fieldsets = (
(
None,
{
'fields': ('title', 'author', 'po_type', 'content',)
}
),
)
admin.site.register(Post,PostAdmin)
admin.site.register(Category,CategoryAdmin)
创建数据库表结构
python manage.py syncdb
此过程中会提示输入管理员的用户名及密码,我这里全是root
启动django web服务
python manage.py runserver 0.0.0.0:9000
admin 后台登录添加数据
127.0.0.1:9000/admin
url与views配置编写为并template传值
setings.py同级主url配置
from django.conf.urls import patterns, include, url
from django.contrib import admin
admin.autodiscover()
urlpatterns = patterns('',
url(r'^', include('blog.urls')),
url(r'^admin/', include(admin.site.urls)),
)
blog 应用url配置
from django.conf.urls import patterns, include, url
urlpatterns = patterns('',
url(r"^$", "blog.views.index", name="index"),
url(r"^post/(?P<pk>\d+)/$", "blog.views.post", name="post"),
url(r'^(?P<id>\d+)/$', 'blog.views.detail', name='detail'),
url(r"^category/(?P<pk>\d+)/$", "blog.views.category", name="category"),
url(r'^tag(?P<tag>\w+)/$', 'blog.views.search_tag', name = 'search_tag'),
url(r'^search/$','blog.views.blog_search', name = 'search'),
)
blog 应用views编写:
# -*- coding: utf-8 -*-
from django.shortcuts import render_to_response, get_list_or_404, get_object_or_404
from django.template import RequestContext
from django.http import Http404
from blog.models import Post, Category
def index(request):
"""blog列表"""
categories = Category.objects.all()
posts = Post.objects.all()
return render_to_response("blog/index.html",
{"posts": posts,
"categories": categories
},
context_instance=RequestContext(request))
def post(request, pk):
"""单篇文章"""
categories = Category.objects.all()
post = get_object_or_404(Post, pk=pk)
return render_to_response("blog/post.html",
{"post": post,
"categories": categories
},
context_instance=RequestContext(request))
def detail(request, id):
try:
post = Post.objects.get(id=str(id))
except Post.DoesNotExist:
raise Http404
return render(request, 'blog/post.html', {'post' : post})
def category(request, pk):
"""相应分类下的文章检索"""
try:
cate = Category.objects.get(pk=pk)
except Category.DoesNotExist: ## 读取分类,如果不存在,则引发错误,并404
raise Http404
posts = cate.post_set.all() ## 获取分类下的所有文章
return render_to_response('blog/index.html', ## 使用首页的文章列表模版,但加入了的一个`is_category`开关
{"posts": posts,
"is_category": True,
"cate_name": cate.name,
"categories": Category.objects.all()},
context_instance=RequestContext(request))
def blog_search(request):
if 's' in request.GET:
s = request.GET['s']
if not s:
return render_to_response('blog/index.html')
else:
post_list = Post.objects.filter(title__icontains = s)
if len(post_list) == 0 :
return render_to_response('blog/archives.html', {'post_list' : post_list,
'error' : True})
else :
return render_to_response('blog/archives.html', {'post_list' : post_list,
'error' : False})
return redirect('/')
def search_tag(request, tag):
print tag,
try:
post_list = Post.objects.filter(po_type__iexact = tag) #contains
except Post.DoesNotExist :
raise Http404
return render_to_response('tag.html', {'post_list' : post_list})
模板处理和样式处理
参考源代码这里
最终结果如下:
用django框架做自己的blog的更多相关文章
- Django框架-目录文件简介
Rhel6.5 Django1.10 Python3.5 Django框架-目录文件简介 1.介绍Django Django:一个可以使Web开发工作愉快并且高效的Web开发框架. 使用Django, ...
- Django框架全面讲解
Python的WEB框架有Django.Tornado.Flask 等多种,Django相较与其他WEB框架其优势为:大而全,框架本身集成了ORM.模型绑定.模板引擎.缓存.Session等诸多功能. ...
- Django框架之中间件与Auth
Django框架之中间件与Auth模块一 cbv加装饰器 -先导入:from django.utils.decorators import method_decorator -1 可以在方法上加装饰器 ...
- web 框架的本质及自定义web框架 模板渲染jinja2 mvc 和 mtv框架 Django框架的下载安装 基于Django实现的一个简单示例
Django基础一之web框架的本质 本节目录 一 web框架的本质及自定义web框架 二 模板渲染JinJa2 三 MVC和MTV框架 四 Django的下载安装 五 基于Django实现的一个简单 ...
- Django 框架 基本知识
一.什么事web框架 框架,即framework,特指为解决一个开放性问题而设计的具有一定约束性的支持结构,使用框架可以使我们快速开发特定的系统,简单来说,就是讲实现方式的底层结构进行封装,提供相应的 ...
- 第三百零四节,Django框架,urls.py模块,views.py模块,路由映射与路由分发以及逻辑处理——url控制器
Django框架,urls.py模块,views.py模块,路由映射与路由分发以及逻辑处理——url控制器 这一节主讲url控制器 一.urls.py模块 这个模块是配置路由映射的模块,当用户访问一个 ...
- 框架----Django框架知识点整理
一.cbv cbv(class-base-view) 基于类的视图 fbv(func-base-view) 基于函数的视图 a.基本演示 urlpatterns = [ url(r'^login.ht ...
- 第六模块:WEB框架开发 第1章·Django框架开发88~128
88-Ajax简介 89-Ajax的简单实现 90-基于Ajax的传递数据 91-基于Ajax的登录验证 92-基于Form表单的文件上传 93-请求头之contentType 94-Ajax传递js ...
- 第六模块:WEB框架开发 第1章·Django框架开发1~50
01-Django基础介绍 02-Web应用程序1 03-Web应用程序2 04-http请求协议1 05-http请求协议2 06-http协议之响应协议 07-wsgire模块1 08-wsgir ...
随机推荐
- 团队Alpha冲刺(四)
目录 组员情况 组员1(组长):胡绪佩 组员2:胡青元 组员3:庄卉 组员4:家灿 组员5:凯琳 组员6:丹丹 组员7:何家伟 组员8:政演 组员9:鸿杰 组员10:刘一好 组员:何宇恒 展示组内最新 ...
- HDU 5273 Dylans loves sequence 暴力递推
题目链接: hdu:http://acm.hdu.edu.cn/showproblem.php?pid=5273 bc:http://bestcoder.hdu.edu.cn/contests/con ...
- 3dContactPointAnnotationTool开发日志(三三)
添加背景图片后发现Runtime Transform Gizmo无法选中物体了: 于是改了一下EditorObjectSelection.cs中的WereAnyUIElementsHovere ...
- PHP初级
通过form get post表单提交的数据,数据内容由用户填写或选择而得到!
- MachineLearning ---- lesson 1
该博文系列是Andrew NG教授的课程笔记,有兴趣的朋友可以在Coursera或者网易公开课上找到该课程. Supervised Learning 下图是一个监督学习回归分析的例子.该图旨在预测房价 ...
- Struts访问序号的设置
- bzoj1853-大包子的幸运数字
题意 称只含有 6 和 8 的数字为幸运数字.称幸运数字的倍数为类幸运数字.求 \([l,r]\) 中有多少个类幸运数字.\(1\le l,r\le 10^{10}\) . 分析 幸运数字最多有 \( ...
- bzoj2013[CEOI2010] A huge tower
题意 有N(2<=N<=620000)快砖,要搭一个N层的塔,要求:如果砖A恰好在砖B上面,那么A不能比B的长度+D要长.问有几种方法,输出 答案 mod 1000000009的值 分析 ...
- 【bzoj3456】城市规划 容斥原理+NTT+多项式求逆
题目描述 求出n个点的简单(无重边无自环)无向连通图数目mod 1004535809(479 * 2 ^ 21 + 1). 输入 仅一行一个整数n(<=130000) 输出 仅一行一个整数, 为 ...
- appium使用H5怎么定位元素
允许是一个class,如果遇到有多个class,只能填写一个. 对于移动端H5元素定位采用Chromedriver的解决方案,具体操作如下: 1.手机安装Chrome浏览器 2.开启USB调试模式,并 ...