首页 > 代码库 > Django快速搭建Blog

Django快速搭建Blog

 创建工程     

 

创建mysite工程项目:

D:/djpy> django-admin.exe startproject mysite

工程目录结构:

技术分享

manage.py ----- Django项目里面的工具,通过它可以调用django shell和数据库等。

settings.py ---- 包含了项目的默认设置,包括数据库信息,调试标志以及其他一些工作的变量。

urls.py ----- 负责把URL模式映射到应用程序。

 

 

创建blog应用      

 

在mysite目录下创建blog应用

D:/pydj> cd mysite
D:/djpy/mysite$ python manage.py startapp blog

目录结构:

技术分享

 

初始化admin后台数据库        

 

  python 自带SQLite数据库,Django支持各种主流的数据库,这里为了方便推荐使用SQLite,如果使用其它数据库请在settings.py文件中设置。

切换到mysite创建数据库:

D:/djpy/mysite$ python manage.py migrate
D:/djpy/mysite$  python manage.py createsuperuser




 

设置admin应用     

  

  admin 是Django 自带的一个后台管理系统。

1、添加blog应用,打开mysite/mysite/settings.py 文件:

# Application definitionINSTALLED_APPS = (    ‘django.contrib.admin‘,    ‘django.contrib.auth‘,    ‘django.contrib.contenttypes‘,    ‘django.contrib.sessions‘,    ‘django.contrib.messages‘,    ‘django.contrib.staticfiles‘,    ‘blog‘,
)

 在列表末尾,添加blog 应用

 

2、在我们创建django项目时,admin就已经创建,打开mysite/mysite/urls.py文件:

from django.conf.urls import include, urlfrom django.contrib import admin

urlpatterns = [
    url(r‘^admin/‘, include(admin.site.urls)),
]

 

3、启动django容器

D:\pydj\mysite>python manage.py runserverPerforming 
system checks...
System check identified no issues (0 silenced).
October 04, 2015 - 20:56:45Django version 1.8.2, using settings ‘mysite.settings‘Starting development server at http://127.0.0.1:8000/Quit the server with CTRL-BREAK.

  

4、访问后台应用

http://127.0.0.1:8000/admin

 

 输入用户、密码,用户名密码为第一次创建数据库时创建的。回想“设置数据库”时的设置。

 

 

设计Model(即设计数据库表)  

 

1、设计model

  现在我们打开blog目录下的models.py文件,这是我们定义blog数据结构的地方。打开mysite/blog/models.py 文件进行修改:

from django.db import models
from django.contrib import admin

# Create your models here.

class BlogsPost(models.Model):
    title = models.CharField(max_length = 150)
    body = models.TextField()
    timestamp = models.DateTimeField()

admin.site.register(BlogsPost)

 

2、 再次初始化数据库

D:\pydj\mysite>python manage.py makemigrations blog
Migrations for ‘blog‘:
  0001_initial.py:    - Create model BlogsPost

D:\pydj\mysite>python manage.py migrate

 

 

3、再次runserver启动服务,访问admin后台,创建文章。

  登陆成功选择add 创建博客

技术分享

技术分享

输入博客标题,正文、日期时间、点击save 创建博客。

技术分享

 

 

 

设置admin 的BlogsPost界面   

 

  打开mysite/blog/models.py 文件,做如下修改:

from django.db import modelsfrom django.contrib import admin# Create your models here.class BlogsPost(models.Model):
    title = models.CharField(max_length = 150)
    body = models.TextField()
    timestamp = models.DateTimeField()class BlogPostAdmin(admin.ModelAdmin):
    list_display = (‘title‘,‘timestamp‘)
    
admin.site.register(BlogsPost,BlogPostAdmin)

 

创建BlogPostAdmin类,继承admin.ModelAdmin父类,以列表的形式显示BlogPost的标题和时间。

技术分享

 

 

创建blog的公共部分

从Django的角度看,一个页面具有三个典型的组件:

一个模板(template):模板负责把传递进来的信息显示出来。

一个视图(view):视图负责从数据库获取需要显示的信息。

一个URL模式:它负责把收到的请求和你的试图函数匹配,有时候也会向视图传递一些参数。

 

 

创建模板  

 

在blog项目下创建templates目录(mysite/blog/templates/),在目录下创建模板文件index.html,内容如下:

{% for post in posts %}    <h2>{{ post.title }}</h2>
    <p>{{ post.timestamp }}</p>
    <p>{{ post.body }}</p>{% endfor%}

 

 

创建视图函数   

 

打开mysite/blog/views.py文件:

#coding=utf-8from django.shortcuts import renderfrom blog.models import BlogsPostfrom django.shortcuts import render_to_response# Create your views here.def index(request):
    blog_list = BlogsPost.objects.all()    return render_to_response(‘index.html‘,{‘blog_list‘:blog_list})

blog_list = BlogPost.objects.all() :获取数据库里面所拥有BlogPost对象

render_to_response()返回一个页面(index.html),顺带把数据库中查询出来的所有博客内容(blog_list)也一并返回。

 

 

创建blog的URL模式      

 

在mysite/urls.py文件里添加blog的url:

#coding=utf-8from django.conf.urls import patterns, include, urlfrom django.contrib import admin

urlpatterns = patterns(‘‘,
    url(r‘^admin/‘, include(admin.site.urls)),
    url(r‘^index/$‘, ‘blog.views.index‘),
)

 

再次启动服务($ python manage.py runserver),访问blog应用(http://127.0.0.1:8000/index/


当然,读者可以继续到admin后台添加blog,从而刷新这个页是否显示新添加的blog。

 

 

添加样式      

 

创建基础模板

在mysite/blog/templates目录里创建base.html的模板:

<html>
      <style type="text/css">
        body{color:#efd;background:#453;padding:0 5em;margin:0}
        h1{padding:2em 1em;background:#675}
        h2{color:#bf8;border-top:1px dotted #fff;margin-top:2em}
        p{margin:1em 0}
      </style>
     
      <body>
        <h1>blog</h1>
        <h3></h3>
        {% block content %}
        {% endblock %}      </body></html>

 

修改index.html模板,让它引用base.html模板和它的“content”块。

{% extends "base.html" %}
  {% block content %}
      {% for post in posts %}      <h2>{{  post.title }}</h2>
      <p>{{ post.timestamp | date:"1,F jS"}}</p>
      <p>{{ post.body }}</p>
      {% endfor %}
  {% endblock %}


Django快速搭建Blog