day04 django进阶知识点
今日概要:
- 模板
- 中间件
- ORM操作(pymysql + SQL语句)
- session和cookie
- 缓存(很多种方式)
内容回顾
-
请求周期
-
路由系统
- 最基本路由关系
- 动态路由(含正则)
- 路由分发不同的app中 + include + 本质 + name + namespace
-
视图
-
类和函数(FBV和CBV)
-
参数 request
- 请求数据
- 自定义数据
-
响应
HttpResponse/JsonResponse/render/redirect return HttpResponse("...") 响应头 obj = HttpResponse("...") obj['xxxxx'] = "值" return obj
-
-
-
其他知识
-
虚拟环境
-
纯净版项目,内置app功能去掉。
-
多app,嵌套到apps目录。
-
pycharm创建django项目 + 虚拟环境
- 最新的django项目
- 低版本(环境+项目+django文件模板)
-
settings配置
django默认settings [先加载] 500 项目目录settings [后加载] 20
-
静态资源
- 静态文件,项目必备【项目根目录,每个app目录下static - app注册顺序】
- 媒体文件,用户上传
-
1.模板
1.1 寻找html模板
python
TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates',
'DIRS': [os.path.join(BASE_DIR, 'templates')],
'APP_DIRS': True,
'OPTIONS': {
'context_processors': [
'django.template.context_processors.debug',
'django.template.context_processors.request',
# 'django.contrib.auth.context_processors.auth',
# 'django.contrib.messages.context_processors.messages',
],
},
},
]
优先去项目根目录 > 每个已注册的app的templates目录找。
如何选择:
- 简单的项目,模板都放在根目录。
- 复杂的项目,模板放在各自的app中,公共部分放在templates目录。
扩展:修改内置app的模板也是同样的套路。
1.2 模板处理的本质
渲染完成后,生成了字符串,再返回给浏览器。
data:image/s3,"s3://crabby-images/4e1be/4e1bebef7f6452a43ae939c8cee235d503438443" alt=""
data:image/s3,"s3://crabby-images/d1833/d18335a4edccf88c0d4460531e1fc57777947b3d" alt=""
1.3 常用语法
data:image/s3,"s3://crabby-images/508e7/508e71e4edc5542071175bf1fd1a4a109bf8a222" alt=""
1.4 内置函数
在django模板语法中提供了内置函数让我们来。
data:image/s3,"s3://crabby-images/d6fc1/d6fc1e19beb12f4f99d7509b53f169a94f0b41ab" alt=""
1.5 自定义模板功能
data:image/s3,"s3://crabby-images/347a2/347a293b857859f0b87100c9dc629b9b45070331" alt=""
三种方式:
-
filter
- 数据处理,参数:1~2个 - 数据处理,if条件
-
simple_tag
参数无限制 & 返回文本
-
inclusion_tag
参数无限制 & HTML片段
需求来了:根据用户权限不同显示不同的菜单。
data:image/s3,"s3://crabby-images/02f2e/02f2e7d1a87260b54ef1d95d438efffaef55044c" alt=""
1.6 继承和母版
data:image/s3,"s3://crabby-images/e0b8a/e0b8adf25dae16a640d9c5137f1d1ac2f9a058ba" alt=""
data:image/s3,"s3://crabby-images/3b294/3b294435ee72e664389728551060432a11808813" alt=""
1.7 模板的导入
data:image/s3,"s3://crabby-images/b5f0b/b5f0bd401d9a34a4eaad475669534c6b549f458b" alt=""
2.django中间件
data:image/s3,"s3://crabby-images/18bdd/18bdda7815b92631813845234db01bb5d5f473ac" alt=""
- 类
- 定义方法
- 注册
2.1 原始方式
data:image/s3,"s3://crabby-images/0ccca/0ccca22e697d8c981d8c719ce3c72c1076601207" alt=""
data:image/s3,"s3://crabby-images/84930/849309dfda49f4d7ba0f8b19cb1004fea3783d24" alt=""
2.2 MiddlewareMixin(建议)
data:image/s3,"s3://crabby-images/bad36/bad36f37d74ec3d138428c3e88a3e3c45f3e6283" alt=""
data:image/s3,"s3://crabby-images/448a1/448a19ecb35fda5221ae2604da0d6090990c54d5" alt=""
注意:django1版本。
源码:
-
面向对象
pythonclass MyMd(object): def __init__(self....): pass def __call__(self,....): pass django内部默认执行call方法,传入参数。
-
反射
pythonclass MyMd(object): def __init__(self....): pass def __call__(self,....): if hasattr(self,'process_request'): response = self.process_request(request) ... django内部默认执行call方法,传入参数。
pythonclass MiddlewareMixin: def __init__(self, get_response=None): self.get_response = get_response def __call__(self, request): response = None if hasattr(self, 'process_request'): response = self.process_request(request) response = response or self.get_response(request) if hasattr(self, 'process_response'): response = self.process_response(request, response) return response class MyMd(MiddlewareMixin): def process_request(self,request): ... def process_response(self,request, response): ... django内部默认执行call方法,传入参数。
data:image/s3,"s3://crabby-images/0912d/0912d1bf2730389bdd0189d413abe0f6fbb2df8a" alt=""
data:image/s3,"s3://crabby-images/a9370/a9370d42ced1518734862acce48363a542c9183c" alt=""
data:image/s3,"s3://crabby-images/414c8/414c81b6452b77a76078479f12277f6473468b6e" alt=""
疑问:prcess_request的执行时,是否已执行了路由匹配?
request.resolver_match
注意:process_view是在django中源码中写死了。
data:image/s3,"s3://crabby-images/1b3ac/1b3acb7554a28cf679f8f9e8328ded5df49a7876" alt=""
2.3 其他
data:image/s3,"s3://crabby-images/9fb54/9fb5494486bd7c796324c20b6b667320c2c7e67a" alt=""
data:image/s3,"s3://crabby-images/e5a86/e5a865613b1f02c77ba95096a55ff66969711313" alt=""
小结
- 定义中间类
- 类方法
- process_request
- process_view
- process_reponse
- process_exception,视图函数出现异常,自定义异常页面。
- process_template_response,视图函数返回
TemplateResponse
对象 or 对象中含有.render方法。
data:image/s3,"s3://crabby-images/fad0e/fad0e02e5d6620bc46e8660b98e1c7dc3064cca5" alt=""
3.ORM操作
orm,关系对象映射,本质翻译的。
data:image/s3,"s3://crabby-images/2acc9/2acc983825809caaf384d59306c25f54569d3e9c" alt=""
3.1 表结构
实现:创建表、修改表、删除表。
在app中的models.py中按照规则编写类 ===> 表结构。
-
编写类
pythonfrom django.db import models class UserInfo(models.Model): name = models.CharField(max_length=16) age = models.IntegerField()
-
注册app
pythonINSTALLED_APPS = [ # 'django.contrib.admin', # 'django.contrib.auth', # 'django.contrib.contenttypes', # 'django.contrib.sessions', # 'django.contrib.messages', 'django.contrib.staticfiles', 'apps.app01.apps.App01Config', 'apps.app02.apps.App02Config', ]
-
命令,django根据models中类生成一个
对数据库操作的配置文件
=>migrations
python manage.py makemigrations
-
命令,读取已经注册么给app中的migrations目录将配置文件 -> 转换成:生成表,修改表 SQL -> 连接数据库去运行。
pythonpython manage.py migrate
-
那个数据库?
-
数据库账户和密码?
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
}
}
-
常见问题:请不要再手动去修改数据的表结构 + 时刻保证 ORM和数据表是对应。
3.1.1 常见字段和参数
-
字段
CharField SmallIntegerField IntegerField BigIntegerField DateField DateTimeField BooleanField -> 其实数据库不支持真假,根据SmallIntegerField创造出来出来。 0 1 DecimalField -> 精确的小数
-
参数
pythonname = models.CharField(verbose_name="姓名", max_length=16) name = models.CharField(verbose_name="姓名", max_length=16, default="哈哈哈") # 经常查询,速度快(MySQL,https://www.bilibili.com/video/BV15R4y1b7y9) name = models.CharField(verbose_name="姓名", max_length=16, default="哈哈哈", null=True, blank=True, db_index=True) email = models.CharField(verbose_name="姓名", max_length=16, default="哈哈哈", null=True, blank=True, unique=True) # 在数据库存储时只能是:sh、bj (上海、北京一般用于页面显示中文) code = models.CharField(verbose_name="姓名", max_length=16, choices=(("sh", "上海"), ("bj", "北京")),default="sh")
python# 不用 max_length=16 count = models.IntegerField(verbose_name="数量", default=1, null=True, blank=True, unique=True) code = models.IntegerField(verbose_name="性别",choices=((1, "男"), (2, "女")),default=1)
pythonregister_date = models.DateField(verbose_name="注册时间", auto_now=True)
pythonamount = models.DecimalField(verbose_name="余额", max_digits=10, decimal_places=2)
示例:
python
from django.db import models
class UserInfo(models.Model):
name = models.CharField(verbose_name="姓名", max_length=16, db_index=True)
age = models.PositiveIntegerField(verbose_name="年龄")
email = models.CharField(verbose_name="邮箱", max_length=128, unique=True)
amount = models.DecimalField(verbose_name="余额", max_digits=10, decimal_places=2, default=0)
register_date = models.DateField(verbose_name="注册时间", auto_now=True)
class Goods(models.Model):
title = models.CharField(verbose_name="标题", max_length=32)
# detail = models.CharField(verbose_name="详细信息", max_length=255)
detail = models.TextField(verbose_name="详细信息")
price = models.PositiveIntegerField(verbose_name="价格")
count = models.PositiveBigIntegerField(verbose_name="库存", default=0)
3.1.2 表关系
data:image/s3,"s3://crabby-images/71248/71248ac7b52353396d97de2ce9b00834029fea14" alt=""
data:image/s3,"s3://crabby-images/626bd/626bd723712dd68bf63de8c75714be3af47d2ded" alt=""
data:image/s3,"s3://crabby-images/82814/82814fc425109cb76dd730cdbb41c9160df7ea10" alt=""
data:image/s3,"s3://crabby-images/2f702/2f7029e286f5178385c054d5d3e44ad006af5f47" alt=""
data:image/s3,"s3://crabby-images/14870/14870e875f3f2e968b76797ed420c87d79cf389a" alt=""
注意:ManyToManyField生成的表字段只能id/bid/gid
小结
设计自己项目的业务时,理清楚表与表之间的关系。
强调:设计项目表结构:表名和字段都不要拼音。
3.2 数据
实现:增删改查。
任务
- 知识点
- 自己的项目设计表结构,自己设计。
- 项目功能描述
- 表结构
- 设计图(提交)
- ORM类(主要)
提交形式:zip包 -> markdown编写。
下节预告:
orm数据操作、cookie和session、缓存、刷票平台(表结构设计)、用户管理、用户+权限菜单