Django:快速搭建简单的Blog

一,创建项目

1, 为blog创建名为mysite的工程项目:

 django-admin.py startproject mysite

2, 项目结构如下:

  mysite
    ├── manage.py
    └── mysite
        ├── __init__.py
        ├── settings.py
        ├── urls.py
        └── wsgi.py
  • manage.py ----- Django项目里面的工具,通过它可以调用django shell和数据库等。
  • settings.py ---- 包含了项目的默认设置,包括数据库信息,调试志以及其他一些工作的变量。
  • urls.py ----- 负责把URL模式射到应用程序。

二 ,运行开发服务器

要马上查看django项目应用的运行,可以使用Django项目里的mange.py

切换到工程目录,执行运行服务器命令:

python manage.py runserver

完成:

打开浏览器,输入访问地址:127.0.0.1:8000

三,创建Blog应用

python manage.py startapp blog

blog应用文件结构如下:

├── blog
│   ├── admin.py
│   ├── __init__.py
│   ├── models.py
│   ├── tests.py
│   └── views.py

四,设计的Model

在blog目录下的models.py是blog应用的心文件之一,是定义blog数据结构的地方。

用编辑器打开models.py

新添BlogPost类,代如下:

from django.db import models

# Create your models here.
class BlogPost(models.Model):
    title = models.CharField(max_length = 150)
    body = models.TextField()
    timestamp = models.DateTimeField()

BlogPost类是django.db.models.Model的一个子类 。它有变量title(blog的题),body(blog的内容部分),timestamp(blog的发表时间)。

五,设置数据库

Dajango支持主流的数据库服务器(MySQL,PostgreSQL,Oracle和MSSQL),但本项目使用SQLite,这里之需要通过一条简单的命令可以创建SQLite数据库。

创建数据库:

切换到工程主目录mysite/下,执行如下命令:

<span ><span >python manage.py syncdb<br></span></span>

出现下面的提示,输入yes,然后按照提示输入相关的信息。完成后会生成一个数据库文件db.sqlite3

六,设置自动admin应用

1,打开mysite/mysite/urls.py,取消注释url(r‘^admin/‘, include(admin.site.urls))

2,编辑mysite/mysite/settings.py,在INSTALLED_APPS里面添blog应用。

添后的代如下:

<span ><span ># Application definition INSTALLED_APPS = (    ‘django.contrib.admin‘,    ‘django.contrib.auth‘,    ‘django.contrib.contenttypes‘,    ‘django.contrib.sessions‘,    ‘django.contrib.messages‘,    ‘django.contrib.staticfiles‘,    ‘blog‘, )<br></span></span>

2,修改mysite/blog/models.py

在最后添一行代:

<span ><span >admin.site.register(BlogPost)<br></span></span>

models.py完整的代如下:

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

# Create your models here.
class BlogPost(models.Model):
    title = models.CharField(max_length = 150)
    body = models.TextField()
    timestamp = models.DateTimeField()

admin.site.register(BlogPost)

3 ,打开浏览器,输入http://127.0.0.1:8000/admin/,输入刚才创建数据库时候填写的帐号就能进入admin界面。

七,试用admin

1, 点击Blog Posts右侧的Add 按钮,添一个帖子。

2,让admin的BlogPost界面更美观

修改blog应用的models.py,为它添一个admin.ModelAdmin的子类BlogPostAdmin.以列表形式显示BlogPost的题和时间。

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

# Create your models here.
class BlogPost(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(BlogPost,BlogPostAdmin)

八,建立Blog的公共部分

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

  • 一个模板(template):模板负责把递进来的信息显示出来。
  • 一个视图(viw):视图负责从数据库获取需要显示的信息。
  • 一个URL模式:它负责把收到的请求和的试图函数匹配,有时候也会向视图递一些参数。

1,创建模板

在blog目录下建立template目录(mysite/blog/templates),创建模板文件archive.html,它的内容如下:

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

2,创建一个视图函数

在app应用的目录下的view.py添视图函数

from django.shortcuts import render
from django.template import loader,Context
from django.http import HttpResponse
from blog.models import BlogPost

# Create your views here.

def archive(request):
    posts = BlogPost.objects.all()
    t = loader.get_template("archive.html")
    c = Context({‘posts‘:posts})
    return HttpResponse(t.render(c))
  • posts = BlogPost.objects.all() :获取数据库里面所拥有BlogPost对象
  • t = loader.get_template("archive.html"):载模板
  • c = Context({‘posts‘:posts}):模板的渲染的数据是有一个字典类的对象Context提供,这里的是一对键值对。

3,创建一个URL模式

第一步,在mysite/urls.py里面取消下面的一行注释:

#

把它变成:

url(r‘^blog/‘, include(‘blog.urls‘)),

第二步:在blog应用里面定义URL,创建一个urls.py(mysite/blog/urls.py)

from django.conf.urls import *
from blog.views import archive

urlpatterns = patterns(‘‘,
                      url(r‘^$‘,archive),
                      )

最后,在浏览器输入如下地址http://127.0.0.1:8000/blog/

九,最后的润色

1,模板的精确定位

在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>my blog</h1>
    {% block content %}
    {% endblock %}
  </body>
</html>

2,修改archive.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 %}

刷新浏览器可以看到效果如下:

3,按日期排序

修改blog 应用下的models.py,为BlogPost添一个Meta嵌套类。如下:

<span >class BlogPost(models.Model):
    title = models.CharField(max_length = 150)
    body = models.TextField()
    timestamp = models.DateTimeField()

    class Meta:
        ordering = (‘-timestamp‘,)<br></span>

刷新浏览器,如下:

文章出处: 开源中国 
文章地址: http://my.oschina.net/matrixchan/blog/184445 
本文地址: http://www.webrube.com/django-python-web_rube/2057 
本文由 噜吧 整理,转载请保留以上信息; 如有侵犯您的版权, 请联系微信: 3715397 。

Django:快速搭建简单的Blog

时间: 2024-10-19 10:10:22

Django:快速搭建简单的Blog的相关文章

django快速搭建一个sample blog(1)

练手之作,前端不太熟,只能瞎胡搞~ Django 的设计鼓励松耦合及对应用程序中不同部分的严格分割. 遵循这个理念的话,要想修改应用的某部分而不影响其它部分就比较容易了.把数据存取逻辑.业务逻辑和表现逻辑组合在一起的概念有时被称为软件架构的 Model-View-Controller(MVC)模式. 在这个模式中, Model 代表数据存取层,View 代表的是系统中选择显示什么和怎么显示的部分,Controller 指的是系统中根据用户输入并视需要访问模型,以决定使用哪个视图的那部分. Dja

django 快速搭建blog

http://www.cnblogs.com/fnng/p/3737964.html django 快速搭建blog 输入博客标题,正文.日期时间.点击save 创建博客. 设置admin 的BlogsPost界面                                                               打开mysite/blog/models.py 文件,做如下修改: from django.db import models from django.contr

拿nodejs快速搭建简单Oauth认证和restful API server攻略

拿nodejs快速搭建简单Oauth认证和restful API server攻略:http://blog.csdn.net/zhaoweitco/article/details/21708955 最近一直在鼓捣这个东西,拿出来分享下一下经验吧,其实很简单,一点也不难. 首先需求是这样,给自己的网站要增加API服务,API分为两种,公共的和私有授权的,授权的使用Oauth方法认证身份,API格式均为JOSN和JSONP. 嗯,别的语言我也没怎么学过,首先是找合适的框架进行实现吧.本身网站使用的e

Django + mysql 快速搭建简单web投票系统

了解学习pyhton web的简单demo 1. 安装Django, 安装pyhton 自行百度 2. 执行命令创建project  django-admin.py startproject mysite 3. 执行命令创建app python manage.py startapp polls 目录结构:   polls/templates/polls 目录  和  polls/admin.py 都是自己手动创建的. 4. 编辑setting.py 添加app  polls  同时打开admin

Django快速搭建Blog

 创建工程      创建mysite工程项目: D:/djpy> django-admin.exe startproject mysite 工程目录结构: manage.py ----- Django项目里面的工具,通过它可以调用django shell和数据库等. settings.py ---- 包含了项目的默认设置,包括数据库信息,调试标志以及其他一些工作的变量. urls.py ----- 负责把URL模式映射到应用程序. 创建blog应用       在mysite目录下创建blog

快速搭建简单的LBS程序——地图服务

很多时候,我们的程序需要提供需要搭建基于位置的服务(LBS),本文这里简单的介绍一下其涉及的一些基本知识. 墨卡托投影 地图本身是一个三维图像,但在电脑上展示时,往往需要将其转换为二维的平面图形,需要通过投影的方式将三维空间中的点映射到二维空间中.地图投影需要建立地球表面点与投影平面点的一一对应关系. 我们经常使用的一种投影算法是墨卡托投影,大概做法就是先拿一个圆柱体使它的轴与地球自转轴重合,先把球面上的点投影到圆柱的侧面上,再把圆柱展开就得到长方形的地图了. 关于墨卡托投影可以更多信息可以参看

Django创建一个简单的blog

1. 使用django-admin.py 创建mysite项目 [email protected]:~/PycharmProjects$ django-admin.py startproject mysite 2. 进入项目目录中,启动服务器,测试连通性 [email protected]:~/PycharmProjects$ cd mysite/ [email protected]-ThinkPad-T450:~/PycharmProjects/mysite$ ./manage.py runs

Castle ActiveRecord框架学习(二):快速搭建简单博客网站

一.数据库 1.数据表 Category:类别标签表(字段Type=1为类别,Type=2为标签) Category_Post:类别标签与文章中间表 Post:文章表 Comment:评论表 2.数据库关系图 3.简单说明 Category和Post表为多对多关系 Post和Comment表 为一对多关系 二.实体类 1.Category类: // 指定数据表,Lazy为延迟加载 [ActiveRecord("Category",Lazy=true)] public class Cat

[ELK]快速搭建简单的日志分析平台

下载ELK(Elasticsearch,Logstash,Kibana) Elasticsearch:wget https://download.elasticsearch.org/elasticsearch/elasticsearch/elasticsearch-1.4.4.tar.gz Logstash:wget https://download.elasticsearch.org/logstash/logstash/logstash-1.4.2.tar.gz Kibana:wget htt