• django 快速搭建blog


    django 快速搭建blog

    2014-05-19 23:38 by 虫师, 420 阅读, 2 评论, 收藏编辑

     

      Django 自称是“最适合开发有限期的完美WEB框架”。本文参考《Django web开发指南》,快速搭建一个blog 出来,在中间涉及诸多知识点,这里不会详细说明,如果你是第一次接触Django ,本文会让你在感性上对Django有个认识,完成本文操作后会让你有兴趣阅读的相关书籍和文档。

    废话少说,come on!!

    本操作的环境:

    ===================

    deepin linux 2013(基于ubuntu)

    python 2.7

    Django 1.6.2

    ===================

     

     

     创建工程                                                                                                          

     

    创建mysite工程项目:

    fnngj@fnngj-H24X:~/djpy$ django-admin.py startproject mysite

    工程目录结构:

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

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

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

     

    运行服务:

    复制代码
    fnngj@fnngj-H24X:~/djpy$ cd mysite/
    fnngj@fnngj-H24X:~/djpy/mysite$ python manage.py runserver
    Validating models...
    
    0 errors found
    May 19, 2014 - 13:16:51
    Django version 1.6.2, using settings 'mysite.settings'
    Starting development server at http://127.0.0.1:8000/
    Quit the server with CONTROL-C.
    复制代码

     

    浏览器访问http://127.0.0.1:8000/

    创建blog应用                                                                                                   

     

    在mysite目录下创建blog应用

    fnngj@fnngj-H24X:~/djpy/mysite$ python manage.py startapp blog

    目录结构:

    设计你的Model

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

    复制代码
    from django.db import models
    
    # Create your models here.
    class BlogsPost(models.Model):
        title = models.CharField(max_length = 150)
        body = models.TextField()
        timestamp = models.DateTimeField()
    复制代码

    创建BlogsPost类,继承django.db.models.Model父类,定义三个变量,title (博客标题),body(博客正文),timestamp(博客创建时间)

     

     

    设置数据库                                                                                                

     

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

    切换到mysite创建数据库:

    复制代码
    fnngj@fnngj-H24X:~/djpy/mysite$ python manage.py syncdb
    Creating tables ...
    Creating table django_admin_log
    Creating table auth_permission
    Creating table auth_group_permissions
    Creating table auth_group
    Creating table auth_user_groups
    Creating table auth_user_user_permissions
    Creating table auth_user
    Creating table django_content_type
    Creating table django_session
    
    You just installed Django's auth system, which means you don't have any superusers defined.
    Would you like to create one now? (yes/no): yes    输入yes/no
    Username (leave blank to use 'fnngj'):    用户名(默认当前系统用户名)
    Email address: fnngj@126.com    邮箱地址
    Password:      密码
    Password (again):      确认密码
    Superuser created successfully.
    Installing custom SQL ...
    Installing indexes ...
    Installed 0 object(s) from 0 fixture(s)
    复制代码

    设置admin应用                                                                                    

      

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

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

    复制代码
    # Application definition
    
    INSTALLED_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文件:

    复制代码
    urlpatterns = patterns('',
        # Examples:
        # url(r'^$', 'mysite.views.home', name='home'),
        # url(r'^blog/', include('blog.urls')),
    
        url(r'^admin/', include(admin.site.urls)),
    )
    复制代码

    去掉admin 设置人注释。

     

    3、将我们创建数据添加到admin后台

    再次打开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)
    复制代码

    4、再次初始化数据库

    复制代码
    fnngj@fnngj-H24X:~/djpy/mysite$ python manage.py syncdb
    Creating tables ...
    Creating table blog_blogspost
    Installing custom SQL ...
    Installing indexes ...
    Installed 0 object(s) from 0 fixture(s)
    复制代码

    5、启动服务

    复制代码
    fnngj@fnngj-H24X:~/djpy/mysite$ python manage.py runserver
    Validating models...
    
    0 errors found
    May 19, 2014 - 14:07:25
    Django version 1.6.2, using settings 'mysite.settings'
    Starting development server at http://127.0.0.1:8000/
    Quit the server with CONTROL-C.
    复制代码

    6、访问admin 后台

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

     

    7、创建博客

    登陆成功选择add 创建博客

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

     

     

     

    设置admin 的BlogsPost界面                                                              

     

      打开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()
    
    class BlogPostAdmin(admin.ModelAdmin):
        list_display = ('title','timestamp')
        
    admin.site.register(BlogsPost)
    复制代码

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

     

     

    创建blog的公共部分

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

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

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

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

     

     

    创建模板                                                                                                  

     

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

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

    设置模板路径,打开mysite/mysite/settings.py文件,在文件底部添加模板路径:

    #template
    TEMPLATE_DIRS=(
        '/home/fnngj/djpy/mysite/blog/templates'
    )

    创建视图函数                                                                                          

     

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

    复制代码
    from django.shortcuts import render
    from django.template import loader,Context
    from django.http import HttpResponse
    from blog.models import BlogsPost
    
    # Create your views here.
    def archive(request):
        posts = BlogsPost.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提供,这里的是一对键值对。

     

     

    创建blog的URL模式                                                                             

     

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

    复制代码
    urlpatterns = patterns('',
        # Examples:
        # url(r'^$', 'mysite.views.home', name='home'),
        
        url(r'^blog/', include('blog.urls')),
        url(r'^admin/', include(admin.site.urls)),
    )
    复制代码

    在mysite/blog/目录下创建urls.py文件:

    复制代码
    from django.conf.urls import *
    from blog.views import archive
    
     
    urlpatterns = patterns('',
                          url(r'^$',archive),
                          )
    复制代码

    之所以在blog应用下面又创建urls.py文件,是为了降低耦合度。这样mysite/urls.py文件针对的是每个项目的url。

     

    再次启动服务($ python manage.py runserver),访问blog应用(http://127.0.0.1:8000/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>
    复制代码

     

    修改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 %}
    复制代码

    再次刷新博客页面:

      请系统的学习django web框架,然后在此基础上做更多的扩展,开发自己真正的blog 

     
     
    分类: python
  • 相关阅读:
    数据库之01-数据库概述
    Bootstrap框架
    jQuery
    补充:html速查表
    BOM,DOM相关案例
    BOM,DOM
    函数,词法分析,内置对象和方法
    前端 之 JaveScript 基础语法: 数据类型; 运算符; 数据转换; 流程控制; 常用内置对象;
    favicon.ioc使用以及注意事项
    redux-undo
  • 原文地址:https://www.cnblogs.com/Leo_wl/p/3738212.html
Copyright © 2020-2023  润新知