大佬教程收集整理的这篇文章主要介绍了Django-中间件,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
中间件就是介于请求和响应处理之间的一道处理过程,相对比较轻量级,并且在全局上改变Django的输入与输出,所以需要谨慎使用。
也就是说中间件帮助我们在视图函数执行之前和执行之后都可以做一些额外的操作,它本质是一个自定义类,类中定义了一些方法,Django框架会在请求的特定时间去执行这些方法。
在SetTings.py文件中MIDDLEWARE配置中可以添加我们自定义的中间件:
当用户发起请求的时候,会依次从上至下经过所有的中间件,当响应的时候又会依次从下至上返回给请求者。
@H_121_41@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', ]
因为中间件是我们自己定义的类,所以它主要可以定义四个方法:
这五个方法的返回值可以是None也可以是一个httpResponse对象,如果是None,则继续按照Django定义的规则向后继续执行,如果是httpResponse对象,则直接将改对象返回给用户
process_request(self,request) # 主要用的
process_response(self, request, responsE) # 主要用的
process_view(self, request, view_func, view_args, view_kwargs)
process_exception(self, request, exception)
示例:
1、在项目中创建一个包,名字自定义,在创建一个py文件,名字自定义,例如:AuthenMD.py
from django.utils.deprecation import Middlewaremixin
class MD1(Middlewaremixin):
# 请求来了先执行它,在到urls.py
def process_request(self, request):
print('MD1的 process_request 操作')
# 响应的数据要先执行它,在到wsgi.py封装发送
def process_response(self, request, responsE):
print('MD1的 process_response 操作')
return response
2、在SetTings.py文件中MIDDLEWARE配置中添加中间件配置
@H_121_41@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', # 添加自定义中间件配置 'app01.AuthenMD.MD1', # 路径项目app01/AuthenMD.py文件中的MD1类 ]
在中间件中最常用和最主要的方法是process_request和process_response
process_request(self, request)
它的返回值可以是None亦可以是httpResponse对象。
None:按照正常流程继续走,交给下一个中间件处理。
httpResponse对象:Django将不执行视图函数,而将相应的对象返回 给浏览器。
from django.utils.deprecation import Middlewaremixin
class MD1(Middlewaremixin):
# 请求来了先执行它,在到urls.py和视图
def process_request(self, request):
print('MD1的 process_request 操作')
注意:
process_response(self, request, responsE)
process_response有两个参数—>request,response
response:是视图函数返回的httpResponse对象。
该方法的返回值必须是httpResponse对象
通常都是返回response
from django.utils.deprecation import Middlewaremixin
class MD1(Middlewaremixin):
# 请求来了先执行它,在到urls.py和视图
def process_request(self, request):
print('MD1的 process_request 操作')
# 不必写return,默认返回None
# 视图执行后执行它,在到wsgi.py封装发送
def process_response(self, request, responsE): # 两个参数必须有,名字自定义
print('MD1的 process_response 操作')
return response # 必须有返回值,返回response就向接力棒一样,随便写返回内容就会被替代
注意:
process_view(self, request, view_func, view_args, view_kwargs)
process_view有四个参数:
view_func:是Django即将使用的视图函数。(实际的函数对象)
view_args:是将传递给视图的位置参数的列表(不包含request)
view_kwargs:是将传递给视图的关键字参数的字典。(不包含request)
返回None或者一个httpResponse对象
None:Django将继续处理这个请求,执行其他中间件的process_view方法和相应的视图。
httpResponse对象:Django不会调用对应的函数,他将直接执行中间件中的process_response方法,并将应用到改httpResponse并返回结果
from django.utils.deprecation import Middlewaremixin
from django.http import httpResponse
class MD1(Middlewaremixin):
def process_request(self, request):
print('MD1的 process_request 操作')
def process_response(self, request, responsE):
print('MD1的 process_response 操作')
return response
# Django会在调用视图函数之前调用process_view方法
def process_view(self, request, view_func, view_args, view_kwargs):
print('MD1的 process_view 操作')
# 输出
MD1的 process_request 操作
MD1的 process_view 操作
视图 login 操作
MD1的 process_response 操作
注意:
process_exception(self, request, exception)
改方法有两个参数:
exception:视图函数异常产生的Exception对象。
返回None或者一个httpResponse对象
None:则交给下一个中间件的process_exception方法来处理
httpResponse对象:Django将调用模板和中间件中的process_response方法,并返回给浏览器,否则默认处理异常。
from django.utils.deprecation import Middlewaremixin
class MD1(Middlewaremixin):
def process_request(self, request):
print('MD1的 process_request 操作')
def process_response(self, request, responsE):
print('MD1的 process_response 操作')
return response
def process_view(self, request, view_func, view_args, view_kwargs):
print('MD1的 process_view 操作')
def process_exception(self, request, exception):
print('MD1的 process_exception 执行了,——>视图函数出错了')
# 输出
MD1的 process_request 操作
MD1的 process_view 操作
MD1的 process_exception 执行了,——>视图函数出错了
MD1的 process_response 操作
注意:
process_exception方法是在视图函数出现了错误才执行的,否则是不执行的。
views.py文件
from django.shortcuts import render, redirect
def login(request):
if request.method == 'GET':
return render(request, 'login.html')
else:
name = request.POST.get('uname')
pwd = request.POST.get('pwd')
if name == 'xiaoyang' and pwd == '123':
request.session['is_login'] = 'True'
return redirect('index')
else:
return redirect('login')
def index(request):
return render(request, 'index.html')
def quit(request):
request.session.flush() # 删除sessionid,服务端和浏览器都删除
return render(request, 'login.html')
AuthenDm.py 中间件文件
from django.utils.deprecation import Middlewaremixin
from django.shortcuts import redirect
# 白名单,白名单中的不需要验证session
WHITE_LIST = [
'/login/'
]
class MD1(Middlewaremixin):
def process_request(self, request):
if request.path in WHITE_LIST: # 地址在白名单中就放行
return
else:
# 不在白名单中就判断session
is_login = request.session.get('is_login')
if is_login == 'True': # 登录了就放行
return
else: # 没登录就直接跳转到登录页面
return redirect('login')
以上是大佬教程为你收集整理的Django-中间件全部内容,希望文章能够帮你解决Django-中间件所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。