Skip to content

Commit d1ad598

Browse files
committed
write article model
1 parent 5e04f34 commit d1ad598

25 files changed

+281
-0
lines changed

article/__init__.py

Whitespace-only changes.
132 Bytes
Binary file not shown.
173 Bytes
Binary file not shown.
952 Bytes
Binary file not shown.
212 Bytes
Binary file not shown.

article/admin.py

+3
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,3 @@
1+
from django.contrib import admin
2+
3+
# Register your models here.

article/apps.py

+5
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,5 @@
1+
from django.apps import AppConfig
2+
3+
4+
class ArticleConfig(AppConfig):
5+
name = 'article'

article/migrations/0001_initial.py

+32
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,32 @@
1+
# Generated by Django 2.1 on 2018-08-24 16:13
2+
3+
from django.conf import settings
4+
from django.db import migrations, models
5+
import django.db.models.deletion
6+
import django.utils.timezone
7+
8+
9+
class Migration(migrations.Migration):
10+
11+
initial = True
12+
13+
dependencies = [
14+
migrations.swappable_dependency(settings.AUTH_USER_MODEL),
15+
]
16+
17+
operations = [
18+
migrations.CreateModel(
19+
name='Article',
20+
fields=[
21+
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
22+
('title', models.CharField(max_length=100)),
23+
('body', models.TextField()),
24+
('created', models.DateTimeField(default=django.utils.timezone.now)),
25+
('updated', models.DateTimeField(auto_now=True)),
26+
('author', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL)),
27+
],
28+
options={
29+
'ordering': ('-created',),
30+
},
31+
),
32+
]

article/migrations/__init__.py

Whitespace-only changes.
Binary file not shown.
Binary file not shown.

article/models.py

+46
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,46 @@
1+
from django.db import models
2+
3+
# Django本身具有一个简单又完整的账号系统(User),足以满足一般网站的账号申请、建立、权限、群组等基本功能
4+
# 因此这里导入内建的User模型,以便使用。
5+
from django.contrib.auth.models import User
6+
# timezone 用于处理时间相关事务。
7+
from django.utils import timezone
8+
9+
# Django中所有的模型(Model)都必须继承django.db.models.Model模型,即顶部的导入
10+
# 建立博客文章类 class Article,处理与文章有关的数据,它包含需要的字段和保存数据的行为
11+
class Article(models.Model):
12+
13+
# 定义文章作者。 author 通过 models.ForeignKey 外键与内建的 User 模型关联在一起
14+
# 参数 on_delete 用于指定数据删除的方式,避免两个关联表的数据不一致。通常设置为 CASCADE 级联删除就可以了
15+
author = models.ForeignKey(User, on_delete=models.CASCADE)
16+
17+
# 文章标题。
18+
# models.CharField 为字符串字段,用于保存较短的字符串,比如标题
19+
# CharField 有一个必填参数 max_length,它规定字符的最大长度
20+
title = models.CharField(max_length=100)
21+
22+
# 文章正文。
23+
# 保存大量文本使用 TextField
24+
body = models.TextField()
25+
26+
# 文章创建时间。
27+
# DateTimeField 为一个日期字段
28+
# 参数 default=timezone.now 指定其在创建数据时将默认写入当前的时间
29+
created = models.DateTimeField(default=timezone.now)
30+
31+
# 文章更新时间。
32+
# 参数 auto_now=True 指定每次数据更新时自动写入当前时间
33+
updated = models.DateTimeField(auto_now=True)
34+
35+
# 内部类 class Meta 用于给 model 定义元数据
36+
# 元数据:不是一个字段的任何数据
37+
class Meta:
38+
# ordering 指定模型返回的数据的排列顺序
39+
# '-created' 表明数据应该以倒序排列
40+
ordering = ('-created',)
41+
42+
# 函数 __str__ 定义当调用对象的 str() 方法时的返回值内容
43+
# 它最常见的就是在Django管理后台中做为对象的显示值。因此应该总是为 __str__ 返回一个友好易读的字符串
44+
def __str__(self):
45+
# return self.title 将文章标题返回
46+
return self.title

article/tests.py

+3
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,3 @@
1+
from django.test import TestCase
2+
3+
# Create your tests here.

article/urls.py

+10
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,10 @@
1+
# 引入path
2+
from django.urls import path
3+
4+
# 正在部署的应用的名称
5+
app_name = 'article'
6+
7+
urlpatterns = [
8+
# 目前还没有urls
9+
]
10+

article/views.py

+3
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,3 @@
1+
from django.shortcuts import render
2+
3+
# Create your views here.

db.sqlite3

136 KB
Binary file not shown.

manage.py

+15
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,15 @@
1+
#!/usr/bin/env python
2+
import os
3+
import sys
4+
5+
if __name__ == '__main__':
6+
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'my_blog.settings')
7+
try:
8+
from django.core.management import execute_from_command_line
9+
except ImportError as exc:
10+
raise ImportError(
11+
"Couldn't import Django. Are you sure it's installed and "
12+
"available on your PYTHONPATH environment variable? Did you "
13+
"forget to activate a virtual environment?"
14+
) from exc
15+
execute_from_command_line(sys.argv)

my_blog/__init__.py

Whitespace-only changes.
132 Bytes
Binary file not shown.
2.2 KB
Binary file not shown.
989 Bytes
Binary file not shown.
535 Bytes
Binary file not shown.

my_blog/settings.py

+122
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,122 @@
1+
"""
2+
Django settings for my_blog project.
3+
4+
Generated by 'django-admin startproject' using Django 2.1.
5+
6+
For more information on this file, see
7+
https://docs.djangoproject.com/en/2.1/topics/settings/
8+
9+
For the full list of settings and their values, see
10+
https://docs.djangoproject.com/en/2.1/ref/settings/
11+
"""
12+
13+
import os
14+
15+
# Build paths inside the project like this: os.path.join(BASE_DIR, ...)
16+
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
17+
18+
19+
# Quick-start development settings - unsuitable for production
20+
# See https://docs.djangoproject.com/en/2.1/howto/deployment/checklist/
21+
22+
# SECURITY WARNING: keep the secret key used in production secret!
23+
SECRET_KEY = '__=s9@oixaun$x^g7-4#10wf_*7zvb8)kl1$j82fj&cyq%^o^3'
24+
25+
# SECURITY WARNING: don't run with debug turned on in production!
26+
DEBUG = True
27+
28+
ALLOWED_HOSTS = []
29+
30+
31+
# Application definition
32+
33+
INSTALLED_APPS = [
34+
'django.contrib.admin',
35+
'django.contrib.auth',
36+
'django.contrib.contenttypes',
37+
'django.contrib.sessions',
38+
'django.contrib.messages',
39+
'django.contrib.staticfiles',
40+
41+
'article',
42+
]
43+
44+
MIDDLEWARE = [
45+
'django.middleware.security.SecurityMiddleware',
46+
'django.contrib.sessions.middleware.SessionMiddleware',
47+
'django.middleware.common.CommonMiddleware',
48+
'django.middleware.csrf.CsrfViewMiddleware',
49+
'django.contrib.auth.middleware.AuthenticationMiddleware',
50+
'django.contrib.messages.middleware.MessageMiddleware',
51+
'django.middleware.clickjacking.XFrameOptionsMiddleware',
52+
]
53+
54+
ROOT_URLCONF = 'my_blog.urls'
55+
56+
TEMPLATES = [
57+
{
58+
'BACKEND': 'django.template.backends.django.DjangoTemplates',
59+
'DIRS': [],
60+
'APP_DIRS': True,
61+
'OPTIONS': {
62+
'context_processors': [
63+
'django.template.context_processors.debug',
64+
'django.template.context_processors.request',
65+
'django.contrib.auth.context_processors.auth',
66+
'django.contrib.messages.context_processors.messages',
67+
],
68+
},
69+
},
70+
]
71+
72+
WSGI_APPLICATION = 'my_blog.wsgi.application'
73+
74+
75+
# Database
76+
# https://docs.djangoproject.com/en/2.1/ref/settings/#databases
77+
78+
DATABASES = {
79+
'default': {
80+
'ENGINE': 'django.db.backends.sqlite3',
81+
'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
82+
}
83+
}
84+
85+
86+
# Password validation
87+
# https://docs.djangoproject.com/en/2.1/ref/settings/#auth-password-validators
88+
89+
AUTH_PASSWORD_VALIDATORS = [
90+
{
91+
'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator',
92+
},
93+
{
94+
'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator',
95+
},
96+
{
97+
'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator',
98+
},
99+
{
100+
'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator',
101+
},
102+
]
103+
104+
105+
# Internationalization
106+
# https://docs.djangoproject.com/en/2.1/topics/i18n/
107+
108+
LANGUAGE_CODE = 'en-us'
109+
110+
TIME_ZONE = 'UTC'
111+
112+
USE_I18N = True
113+
114+
USE_L10N = True
115+
116+
USE_TZ = True
117+
118+
119+
# Static files (CSS, JavaScript, Images)
120+
# https://docs.djangoproject.com/en/2.1/howto/static-files/
121+
122+
STATIC_URL = '/static/'

my_blog/urls.py

+26
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,26 @@
1+
"""my_blog URL Configuration
2+
3+
The `urlpatterns` list routes URLs to views. For more information please see:
4+
https://docs.djangoproject.com/en/2.1/topics/http/urls/
5+
Examples:
6+
Function views
7+
1. Add an import: from my_app import views
8+
2. Add a URL to urlpatterns: path('', views.home, name='home')
9+
Class-based views
10+
1. Add an import: from other_app.views import Home
11+
2. Add a URL to urlpatterns: path('', Home.as_view(), name='home')
12+
Including another URLconf
13+
1. Import the include() function: from django.urls import include, path
14+
2. Add a URL to urlpatterns: path('blog/', include('blog.urls'))
15+
"""
16+
from django.contrib import admin
17+
# 记得引入include
18+
from django.urls import path, include
19+
20+
# 存放了映射关系的列表
21+
urlpatterns = [
22+
path('admin/', admin.site.urls),
23+
24+
# 新增代码,配置app的url
25+
path('article/', include('article.urls', namespace='article')),
26+
]

my_blog/wsgi.py

+16
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,16 @@
1+
"""
2+
WSGI config for my_blog project.
3+
4+
It exposes the WSGI callable as a module-level variable named ``application``.
5+
6+
For more information on this file, see
7+
https://docs.djangoproject.com/en/2.1/howto/deployment/wsgi/
8+
"""
9+
10+
import os
11+
12+
from django.core.wsgi import get_wsgi_application
13+
14+
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'my_blog.settings')
15+
16+
application = get_wsgi_application()

0 commit comments

Comments
 (0)