二、Python Django 微型博客

通过简略的操作,就能够在 Django 中实现一个博客 利用

2.1 用模板生成文件

进入到 上篇博客创立的目录中,执行下述命令。

django-admin startapp blog# 也能够应用下述命令python manage.py startapp blog

命令运行之后,生成的目录如下。

相干文件阐明如下:

blog # 根目录    __init__.py    admin.py # 后盾治理    apps.py # 利用设置相干    models.py # 模型,数据库相干    tests.py # 测试相干    views.py # 视图相干    migrations # 数据库变更记录文件夹

接下来批改 my_website 文件夹中的 settings.py 文件,增加 blog 利用,具体代码如下,重点是最初一行。

INSTALLED_APPS = [    'django.contrib.admin',    'django.contrib.auth',    'django.contrib.contenttypes',    'django.contrib.sessions',    'django.contrib.messages',    'django.contrib.staticfiles',    'blog', # 这里是十分重要的]

在 Django 中,如果心愿利用模型、动态文件、模板这些内容,须要在 INSTALLED_APPS 增加对应的利用目录,如果没有设置,利用不会进行加载。

2.2 创立文章模型与数据库构造

一篇博客包含题目,内容,公布工夫等内容,这些都在 Django 中进行创立,外围要批改的是 models.py 文件。

from django.db import models# Create your models here.class Blog(models.Model):    title = models.CharField("题目", max_length=100)    content = models.TextField("内容")    creatr_time = models.DateField("公布工夫")

该类就是模型类,实现一个模型类,须要继承自 models.Model 类,该类用于进行数据库中数据和 Python 对象之间的转换操作。

上面将 Blog 类反射到 sqlite3 数据库中,本阶段请以模拟为主,后续会为你补充残缺相应的常识框架。

manage.py 所在的文件夹中运行下述命令:

python manage.py makemigrations blog

该命令用于查看 blog 中模型文件的变更,因为在上文咱们创立了一个 Blog 类,所以 models.py 文件被批改,当执行上述命令时,会输入如下内容。

>python manage.py makemigrations blogMigrations for 'blog':  blog\migrations\0001_initial.py    - Create model Blog

提醒的信息也为 Create model Blog,提醒创立了一个 Blog 类,上面将 models.py 中的内容在 sqlite3 创立进去,应用的命令为 python manage.py migrate blog,运行后果如下:

> python manage.py migrate blogOperations to perform:  Apply all migrations: blogRunning migrations:  Applying blog.0001_initial... OK

2.3 创立治理后盾

上面通过简略的步骤实现对 blog 表的治理,Django 自带用户认证零碎,通过命令 python manage.py migrate 即可实现。

> python manage.py migrateOperations to perform:  Apply all migrations: admin, auth, blog, contenttypes, sessionsRunning migrations:  Applying contenttypes.0001_initial... OK  Applying auth.0001_initial... OK  Applying admin.0001_initial... OK  Applying admin.0002_logentry_remove_auto_add... OK  Applying admin.0003_logentry_add_action_flag_choices... OK  Applying contenttypes.0002_remove_content_type_name... OK  Applying auth.0002_alter_permission_name_max_length... OK  Applying auth.0003_alter_user_email_max_length... OK  Applying auth.0004_alter_user_username_opts... OK  Applying auth.0005_alter_user_last_login_null... OK  Applying auth.0006_require_contenttypes_0002... OK  Applying auth.0007_alter_validators_add_error_messages... OK  Applying auth.0008_alter_user_username_max_length... OK  Applying auth.0009_alter_user_last_name_max_length... OK  Applying auth.0010_alter_group_name_max_length... OK  Applying auth.0011_update_proxy_permissions... OK  Applying auth.0012_alter_user_first_name_max_length... OK  Applying sessions.0001_initial... OK

该命令创立一些列的数据库表构造,表构造呈现之后,还须要创立登录账号,用到的外围命令是 python manage.py createsuperuser

> python manage.py createsuperuserUsername (leave blank to use 'administrator'): xiangpicaEmail address: dream@163.comPassword:Password (again):The password is too similar to the username.Bypass password validation and create user anyway? [y/N]: ySuperuser created successfully.

筹备工作实现结束,对 admin.py 文件进行批改,留神 admin.py 文件的地位以及模块之间的调用关系。

from django.contrib import adminfrom blog.models import Blog# Register your models here.@admin.register(Blog)class BlogAdmin(admin.ModelAdmin):    pass

在正式运行之前,还须要批改一下网页展现中英文内容,关上 setting.py 文件,批改如下内容。

# LANGUAGE_CODE = 'en-us'LANGUAGE_CODE = 'zh-hans'

筹备工作实现,控制台运行下述命令 python manage.py runserver

> python manage.py runserverWatching for file changes with StatReloaderPerforming system checks...System check identified no issues (0 silenced).March 24, 2021 - 22:22:33Django version 3.1.7, using settings 'my_website.settings'Starting development server at http://127.0.0.1:8000/

此时关上默认页面,展现的内容如下:

批改拜访地址为:http://127.0.0.1:8000/admin,呈现登录窗口,应用上文注册的账号即可拜访。

输出一些文章相干信息进行保留之后,返回列表页面,呈现一个小细节,橙色框内的数据是一个 Blog object,不是文章的题目,持续批改代码。

批改 modes.py 文件,批改内容如下:

from django.db import models# Create your models here.class Blog(models.Model):    title = models.CharField("题目", max_length=100)    content = models.TextField("内容")    creatr_time = models.DateField("公布工夫")    def __str__(self):        return self.title

一个小型的博客实现,你能够对文章进行编辑与删除操作。