Django框架基础-02
Django缓存
cookie
1.说明
当我们服务器在响应数据的同时,希望写⼊⼀些缓存数据到客户端
我们可以选择在响应的同时,将要写⼊到客户端的缓存数据写⼊到⽤户的浏览器的cookie中
2.创建response对象
# 创建响应对象
response = HttpResponse('OK')
# response = JsonResponse({"name":"python"})
# response = redirect(reverse('users:index'))
# response = render('模板')
3.设置cookie response.set_cookie(' 键 ' , ' 值 ' , max_age= 过期时间,单位秒)
response.set_cookie('name', ' python' , max_age= 3600)
4.读取cookie name = request.COOKIES.get('name')
session
1.session说明
1.session和 cookie都可以做缓存数据
2.但是,session是将缓存的数据存储在服务器端 cookie存储缓存数据在⽤户浏览器
3.⼴义:指session机制,会话,⽤于记录多次http请求之间的关系,关系就是状态数据,⽐如登录状态
4.狭义:指session数据,会话数据,记录会话的状态数据,⽐如登录后存储user_id记录登录状态
2.Django中使⽤session说明
1.默认开启了session机制
安装应⽤ ' django.contrib.sessions' ,
注册中间件 ' django.contrib.sessions.middleware.SessionMiddleware' ,
2.存储⽅案
1.默认存储⽅案(数据库) SESSION_ENGINE=' django.contrib.sessions.backends.db',
存储到数据库的django_session这个表
2.本地缓存(本机内存) SESSION_ENGINE=' django.contrib.sessions.backends.cache'
3.混合缓存 SESSION_ENGINE=' django.contrib.sessions.backends.cached_db',先内存找,再数据库找
4.Redis
3.本地缓存的跨机访问问题
问题
1.如果将缓存数据存储到Django程序运⾏空间中
2.⽤户在请求时会由nginx服务器转发请求 可能多次转发到的服务器不⼀样
3.那么如果转发到没有写⼊缓存数据的电脑,将得不到缓存
图解:
4.Redis存储session数据配置
1.安装django-redis pip install django-redis
2.配置缓存后端
# 配置缓存(缓存后端为Redis)
CACHES = {
"default": {
"BACKEND": " django_redis.cache.RedisCache" ,
"LOCATION": "redis://192.168.103.132:6379/1",
"OPTIONS": {
"CLIENT_CLASS": " django_redis.client.DefaultClient" ,
}
}
}
SESSION_ENGINE = " django.contrib.sessions.backends.cache"
SESSION_CACHE_ALIAS = "default"
5.设置和读取session数据
1.代码实现
def session_demo(request):
"""设置和读取session"""
# 设置session
request.session['user_id'] = 100
# 读取session
user_id = request.session.get('user_id')
print(user_id)
return HttpResponse('ok')
2.session机制说明
1.设置session时,会将session数据写⼊到redis数据库,并⽣成session_id作为key
2.设置session时,会将session_id数据写⼊到⽤户浏览器
3.读取session时,会先从request对象中,读取COOKIES中的session_id
4.读取session时,再使⽤session_id读取redis中的session数据
类视图
类视图介绍
1.以类的形式定义视图 继承⾃View
2.代码阅读性好 将多个请求业务逻辑封装在⼀个类的多个函数中
3.扩展性好 可以使⽤类的继承,实现功能的集成
类视图定义和使⽤
1.类视图定义
class DefineClassview(View):
"""类视图定义"""
def get(self, request):
"""GET请求业务逻辑"""
return HttpResponse('GET请求业务逻辑' )
def post(self, request):
"""GET请求业务逻辑"""
return HttpResponse('POST请求业务逻辑' )
2.类视图绑定路由 url(r'^define_classview/$', views.DefineClassview.as_view()),
类视图实现原理: django 源代码
类视图装饰器
1.定义装饰器
def my_decorator(view_func):
"""定义装饰器装饰视图"""
def wrapper(request, *args, **kwargs):
print( ' 装饰器被调⽤了' )
print(request.method)
# 调⽤被装饰的视图
return view_func(request, *args, **kwargs)
return wrapper
2.在路由匹配中使⽤装饰器 url(r'^define_classview/$', views.my_decorator(views.define_classview.as_view())),
3.在类视图中使⽤装饰器
⽅案⼀:装饰整体逻辑
@ method_decorator(my_decorator, name= 'dispatch')
class define_classview(View):
"""类视图定义"""
def get(self, request):
"""GET请求业务逻辑"""
return HttpResponse('GET请求业务逻辑' )
def post(self, request):
"""GET请求业务逻辑"""
return HttpResponse('POST请求业务逻辑' )
⽅案⼆:装饰局部逻辑
@ method_decorator(my_decorator, name= 'post')
class define_classview(View):
"""类视图定义"""
def get(self, request):
"""GET请求业务逻辑"""
return HttpResponse('GET请求业务逻辑' )
def post(self, request):
"""GET请求业务逻辑"""
return HttpResponse('POST请求业务逻辑' )
类视图Mixin扩展类
1.使⽤说明 当类视图中的业务逻辑,在其他类中已经实现,可以将其他类以类扩展的形式继承到类视图
2.扩展类
class ListModelMixin(object):
"""
list扩展类
"""
def list(self, request, *args, **kwargs) :
...
class CreateModelMixin(object):
"""
create扩展类
"""
def create(self, request, *args, **kwargs) :
...
3.继承扩展类
class BooksView( CreateModelMixin, ListModelMixin, View):
"""
同时继承两个扩展类,复⽤list和 create⽅法
"""
def get(self, request):
self.list(request)
...
def post(self, request):
self.create(request)
...
中间件
1.介绍
监听请求和响应的整个过程 类似于Flask⾥⾯的请求勾⼦
可以修改请求和响应信息
2.定义和使⽤
1.定义
项⽬路径/middleware.my_middleware
def my_middleware(get_response):
print( 'init 被调⽤' )
def middleware(request):
print( 'before request 被调⽤' )
response = get_response(request)
print( 'after response 被调⽤' )
return response
return middleware
2.使⽤
MIDDLEWARE = [
' django.middleware.security.SecurityMiddleware' ,
' django.contrib.sessions.middleware.SessionMiddleware' ,
' django.middleware.common.CommonMiddleware' ,
# 'django.middleware.csrf.CsrfViewMiddleware',
' django.contrib.auth.middleware.AuthenticationMiddleware' ,
' django.contrib.messages.middleware.MessageMiddleware' ,
' django.middleware.clickjacking.XFrameOptionsMiddleware' ,
'middleware.my_middleware', # 添加⾃⼰定义的中间件
'middleware.my_middleware2',
]
3.⼯作原理
1.理论说明 •在请求视图被处理前 ,中间件由上⾄下依次执⾏
•在请求视图被处理后 ,中间件由下⾄上依次执⾏
模板
1.模板定义
1.准备模板⽂件夹 项⽬根路径/templates/
2.配置模板查找路径
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' ,
],
},
},
]
3.准备模板⽂件 项⽬根路径/templates/index.html
2.模板渲染
class templates_demo(View):
"""模板演示"""
def get(self,request):
context = {
'city': ' beijing' ,
' alist' :[1 , 2 , 3 ],
' adict' :{
'name': 'python'
}
}
return render(request, 'index.html', context)
3.模板语法
Flaks模板语法整体和Django模板语法⼀致
1.读取列表数据
Django语法 < h1> {{ alist. 0 }}</h1>
Flask语法 < h1> {{ alist[0] }}</h1>
2.遍历循环
Django语法
读取索引:{{forloop.counter}}
遍历为空:{%empty%}
Flask语法
读取索引:{{loop.index}}
遍历为空:{%else%}
3.过滤器
Django语法 最多只能传⼀个参数到过滤器
Flask语法 可以传⼊多个参数到过滤器
4.模板复⽤
Django语法 模板继承
MySQL数据库准备
MySQL数据库ORM介绍
1. O是 object,也就类对象的意思,R 是 relation,翻译成中⽂是关系,也就是关系数据库中数据表的意思,M 是 mapping,是映射的意思。
2. 在ORM框架中,它帮我们把类和数据表进⾏了⼀个映射,可以让我们通过类和类对象就能操作它所对应的表格中的数据。
3. ORM框架还有⼀个功能,它可以根据我们设计的类⾃动帮我们⽣成数据库中的表格,省去了我们⾃⼰建表的过程。
4. django中内嵌了ORM框架,不需要直接⾯向数据库编程,⽽是定义模型类,通过模型类和对象完成数据表的增删改查操作。
5.使⽤步骤
1. 配置数据库连接信息
2. 在 models.py中定义模型类
3. 迁移
4. 通过类和对象完成数据增删改查操作
MySQL数据库驱动介绍
ORM识别的驱动MySQLdb 只⽀持python2版本
安装python3的驱动PyMySQL 并转成MySQLdb这个名字
MySQL数据库配置
1.默认配置
DATABASES = {
'default': {
'ENGINE': ' django.db.backends.sqlite3' ,
'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
}
}
2.配置MySQL数据库
DATABASES = {
'default': {
'ENGINE': ' django.db.backends.mysql' ,
'HOST': '127.0.0.1', # 数据库主机
'PORT': 3306, # 数据库端⼝
'USER': 'root', # 数据库⽤户名
'PASSWORD': 'mysql', # 数据库⽤户密码
'NAME': ' django_demo' # 数据库名字
}
}
3.安装驱动
pip install PyMySQL
配置驱动
from pymysql import install_as_MySQLdb
# 将 python3⽀持的MySQL驱动转成ORM识别的MySQLdb
install_as_MySQLdb()
ORM模型类 模型类定义
# 定义图书模型类BookInfo
class BookInfo(models.Model):
btitle = models.CharField(max_length= 20, verbose_name= ' 名称' )
bpub_date = models.DateField(verbose_name= ' 发布⽇期' )
bread = models.IntegerField(default= 0 , verbose_name= ' 阅读量' )
bcomment = models.IntegerField(default= 0 , verbose_name= ' 评论量' )
is_delete = models.BooleanField(default= False, verbose_name= ' 逻辑删除' )
class Meta:
db_table = 'tb_books' # 指明数据库表名
verbose_name = ' 图书' # 在 admin站点中显示的名称
verbose_name_plural = verbose_name # 显示的复数名称
def __str__( self):
"""定义每个数据对象的显示信息"""
return self.btitle
# 定义英雄模型类HeroInfo
class HeroInfo(models.Model):
GENDER_CHOICES = (
(0 , 'male'),
(1 , 'female')
)
hname = models.CharField(max_length= 20, verbose_name= ' 名称' )
hgender = models.SmallIntegerField(choices=GENDER_CHOICES, default= 0 , verbose_name= ' 性别' )
hcomment = models.CharField(max_length= 200, null= True, verbose_name= ' 描述信息' )
hbook = models.ForeignKey(BookInfo, on_delete=models.CASCADE, verbose_name= ' 图书' ) # 外键
is_delete = models.BooleanField(default= False, verbose_name= ' 逻辑删除' )
class Meta:
db_table = 'tb_heros'
verbose_name = ' 英雄'
verbose_name_plural = verbose_name
def __str__(self):
return self.hname
模型类字段数据类型和选项
1.字段类型
2.选项
模型类迁移建表
1.⽣成迁移⽂件 python manage.py makemigrations
2.执⾏迁移⽂件 python manage.py migrate
shell⼯具和mysql⽇志
1.shell⼯具 python manage.py shell
2.mysql⽇志
sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf
django 基础框架学习 (二)
猜你喜欢
转载自www.cnblogs.com/x931890193/p/9330166.html
今日推荐
周排行