zoukankan      html  css  js  c++  java
  • django 快速搭建blog

    利用Django快速搭建一个简单的Blog。参考自《Django Web开发指南》。

    Django 自称是“最适合开发有限期的完美WEB框架”。
    废话少说,come on!!

    本操作的环境:
    ===================

    Windows 7
    python 3.6
    Django 1.10.5

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

    一,创建项目

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

    django-admin.py startproject mysite

    项目结构如下:

    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 0.0.0.0:8000

    成功运行后就开启了web服务。

    打开浏览器,输入访问地址:127.0.0.1:8000,会看到提示

    It worked!

    三,创建Blog应用、设置admin应用、配置数据库

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

    3.1、创建Blog应用
    python manage.py startapp blog

    blog应用文件结构如下:
    ├── blog
    │ ├── admin.py
    │ ├── __init__.py
    │ ├── models.py
    │ ├── tests.py
    │ └── views.py

    添加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 应用

    在我们创建django项目时,admin就已经创建,打开mysite/mysite/urls.py文件:
    from django.conf.urls import include, url
    from django.contrib import admin

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

    3.2、同步数据库
    python manage.py syncdb
    注意:Django 1.7.1及以上的版本需要用以下命令
    python manage.py makemigrations
    python manage.py migrate

    3.3、清空数据库
    python manage.py flush
    3.4、创建超级管理员
    python manage.py createsuperuser
    # 按照提示输入用户名和对应的密码就好了邮箱可以留空,用户名和密码必填
    # 修改 用户密码可以用:
    python manage.py changepassword username

    再次runserver启动服务,访问admin后台,这个时候使用你的账号密码就可以登录admin后台了。


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

    4.1、添加BlogPost类
    在blog目录下的models.py是blog应用的核心文件之一,是定义blog数据结构的地方。

    用编辑器打开models.py

    新添加BlogPost类,代码如下:

    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.2、再次初始化数据库
    python manage.py makemigrations blog
    python manage.py syncdb
    或者
    python manage.py migrate

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

    4.3、登陆成功选择add 创建博客

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

    4.4、设置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)

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

    五、创建blog的公共部分

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

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

    5.1、创建模板

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

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

    5.2、创建视图函数

    打开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
    from django.shortcuts import render_to_response

    # Create your views here.
    def index(request):
    blog_list = BlogsPost.objects.all()
    return render_to_response('index.html',{'posts':blog_list})

    blog_list = BlogPost.objects.all() :获取数据库里面所拥有BlogPost对象
    render_to_response()返回一个页面(index.html),顺带把数据库中查询出来的所有博客内容(blog_list)也一并返回。

    5.3、创建blog的URL模式

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

    from django.conf.urls import url
    from django.contrib import admin
    from blog.views import index

    urlpatterns = [
    url(r'^admin/', admin.site.urls),
    url(r'^index/$', index),
    ]

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

    如果顺利的话就会看到你刚刚添加的博客。

    5.5、添加样式

    创建基础模板

    在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 %}

    再次刷新博客页面,就会看到添加了样式之后的页面。

  • 相关阅读:
    Linux文件系统_每一个的意义
    Linux启动的流程
    Linux
    awk编程
    Junit测试Controller(MockMVC使用),传输@RequestBody数据解决办法
    spring boot get和post请求,以及requestbody为json串时候的处理
    Spring Boot快速入门
    Spring Boot 实用MyBatis做数据库操作
    极简操作无需root隐藏S8导航栏和状态栏
    springboot(三):Spring boot中Redis的使用
  • 原文地址:https://www.cnblogs.com/zqifa/p/django-1.html
Copyright © 2011-2022 走看看