首页 > 代码库 > 通过django 速成 blog
通过django 速成 blog
1、 创建项目
33进入在python目录下的scripts文件后执行
django-admin.py startproject mysite
这样就生成了名为mysite 的工程。
可执行.\manage.py runserver 运行开发服务器此时, 终端下会输出
登录 http://127.0.0.1:8000/ 显示这样一个页面
同时终端会输出[13/Aug/2014 01:05:14] "GET / HTTP/1.1" 200 1957
从左往右依次为时间戳、请求、http状态码 、 字节数
2、 创建blog应用
执行 .\manage.py startapp blog
这样就创建了blog app, 在项目(mysite)的目录下会有blog的目录。
之后还需要 在mysite 目录下的sittting.py 中找到元组INSTALLED_APPS , 在元组的末尾添上‘blog.app’, (注意逗号)
3、 设计model
在models.py中加入下列代码
from django.db import models
from django.contrib import admin
class BlogPost(models.Model):
title = models.CharField(max_length = 150)
body = models.TextField()
timestamp = models.DateTimeField()
4、 设置数据库
如果是使用sqlite3,只需在setting.py 的 Databases字典中补全 前两项 即‘ENGINE’: ‘django.db.backends.sqlite3‘
‘NAME’ = ****\django.db #为数据存放地址,自定义
然后执行.\manage.py syncdb #同步数据 终端中,会看到下列输出
Creating table auth_message
Creating table auth_group
……..
之后会被问一下与django.contrib.auth app有关的问题,许按步 骤填写
5、 设置自动admin应用
在 settings.py 中 ‘django.contrib.auth’ 下添加下列一行
‘django.contrib.admin’
然后再次执行syncdb命令 ,
设置完app后, 需要为它指定一个URL
在urls.py 中 去掉rl(r‘^admin/‘, include(admin.site.urls)) 前的注释符
最后, 在 models.py 导入admin
from django.contrib import admin
并在最后加上一行注册model的代码
admin.site.register(BlogPost)
6、 试用admin 登录 127.0.0.1:8000/admin 后输入 用户名和密码会看到一下页面
随意编辑几篇 blog并保存。为了然列表更美观在models.py中添加blogpostadmin类,并将它加到注册代码里
from django.db import models
from django.contrib import admin
class BlogPost(models.Model):
title = models.CharField(max_length = 150)
body = models.TextField()
timestamp = models.DateTimeField()
class Meta:
ordering = (‘-timestamp‘,)
class BlogPostAdmin(admin.ModelAdmin):
list_display = (‘title‘, ‘timestamp‘)
admin.site.register(BlogPost, BlogPostAdmin) #regiet blogpost model
刷新一下页面, 会看到
相比原先有了 title 和timestamp 栏
7、 建立blog的公共部分。
创建文件 archive.html 保存到blog\templates中内容如下
{% for post in posts %}
<h2>{{post.title}}</h2>
<p>{{post.timestamp|date}}</p>
<p>{{ post.body}}</p>
{% endfor %}
然后创建视图函数打开blog\view.py文件并输入:
from django.template import loader, Context
from django.http import HttpResponse
from mysite.blog.models import BlogPost
def archive(request):
posts = BlogPost.objects.all()
t = loader.get_template(‘archive.html‘)
c = Context({‘posts‘: posts})
return HttpResponse(t.render(c))
之后再创建 url模式 在mysite/urls.py 添加
url(r‘^blog/‘, include(‘mysite.blog.urls‘)),
这会捕捉任何以blog/开始的请求, 并传递给接下来的url模式
Mysite/blog/urls.py:
from django.conf.urls.defaults import *
from mysite.blog.views import archive
urlpatterns = patterns(‘‘,
url(r‘^$‘, archive),
)
8、 最后润色
创建base.html 文件, 并保存在mysite/blog/templates内容如下:
<html>
<style type="text/css">
body { color: #cdcdcd; backgroud:#cdcdcd; padding: 0 5em; margin: 0}
h1 { padding:2em 1em; backgroud: #675}
h2{color: #cdcdcd; border-top: 1px dotted #cdcdcd; margin-top; 2em}
p {margin: 1em 0}
</style>
<body>
<h1>mysite.example.com</h1>
{% block content %}
{% endblock %}
</body>
</html>
然后更新achive.html内容:
{% extends "base.html" %}
{% block content %}
{% for post in posts %}
<h2>{{post.title}}</h2>
<p>{{post.timestamp|date}}</p>
<p>{{ post.body}}</p>
{% endfor %}
{% endblock %}
运行后登陆http://127.0.0.1:8000/blog/
可在models.py文件中添加嵌套类 Meta:是blog 按顺序排序
from django.db import models
from django.contrib import admin
class BlogPost(models.Model):
title = models.CharField(max_length = 150)
body = models.TextField()
timestamp = models.DateTimeField()
class Meta:
ordering = (‘-timestamp‘,)
class BlogPostAdmin(admin.ModelAdmin):
list_display = (‘title‘, ‘-timestamp‘)
admin.site.register(BlogPost, BlogPostAdmin) #regiet blogpost model
‘-timestamp’为降序 ‘timestamp’为升序