1-中间件的概念
Django中间件(Middleware)是一个轻量级、底层的“插件”系统,可以介入Django的请求和响应处理过程,修改Django的输入或输出.
用户—通过请求request----中间件----通过请求quest----urls以及视图层
urls以及视图层–返回响应response—中间件—返回响应response—用户
2-django中的中间件
django 中的中间件(middleware),在django中,中间件其实就是一个类,在请求到来和结束后,django会根据自己的规则在合适的时机执行中间件中相应的方法。
在django项目的settings模块中,有一个 MIDDLEWARE_CLASSES 变量,其中每一个元素就是一个中间件.
3-中间的执行顺序
请求以自上而下的顺序通过所有的层,view函数处理之后,响应以自下而上的顺序通过所有的层,期间经过的每个中间件都会对请求或者响应进行处理
4-中间件的结构
中间件中可以定义5个方法,分别是:
process_request(self,request) :
执行视图之前被调用,在每个请求上调用,返回None或HttpResponse对象
process_view(self, request, callback, callback_args, callback_kwargs):
调用视图之前被调用,在每个请求上调用,返回None或HttpResponse对象
process_template_response(self,request,response):
在视图刚好执行完毕之后被调用,在每个请求上调用,返回实现了render方法的响应对象
process_exception(self, request, exception)
当视图抛出异常时调用,在每个请求上调用,返回一个HttpResponse对象
process_response(self, request, response)
所有响应返回浏览器之前被调用,在每个请求上调用,返回HttpResponse对象
5-自定义中间件第一种方式例子
在项目根目录下app下创建mymiddleware.py文件(在自己想要在哪个APP目录下创建.py文件)
在mymiddleware.py文件下
from django.utils.deprecation import MiddlewareMixin
class MyMidd(MiddlewareMixin):
def process_request(self,request):
print("自定义请求方法")
return None
def process_response(self, request, response):
print("自定义响应方法")
return response
在settings.py下的middleware下配置
例子实现:所有页面检查用户是否登录
views.py
def index(request):
"""
查找 如果查到了就直接显示登录状态 没有就提示登录
:param request:
:return:
"""
username = getattr(request,"username")#获取request中的username属性
return render(request,'dom/index.html',context={
'username':username,
})
class LoginResponse(View):
def get(self, request):
return render(request,"dom/login.html")
def post(self, request):
"""
1-获取参数
2-校验参数
3-业务逻辑
4-返回响应
:param request:
:return:
"""
#1-获取用户名
username = request.POST.get("username")
#2-设置session
request.session["username"] = username
#3-设置时间 判断用户是否有勾选记住我 如果勾选 设置15天登录
#没有勾选 当会话结束时结束登录状态
request.session.set_expiry(0)
return redirect(reverse('dom:index'))
def exit(request):
request.session.flush()
return redirect(reverse("dom:index"))
在mymiddleware.py文件下
class UserLogin(MiddlewareMixin):
def process_request(self,request):
username = request.session.get("username", "未登录")
#设置属性
setattr(request,'username',username)
return None
def process_response(self, request, response):
print("自定义响应方法")
return response
urls.py
from django.urls import path
from . import views
app_name="LG"
urlpatterns = [
path('index/',views.index,name='index'),
path('register/',views.register,name='register'),
path('login/',views.login,name='login'),
path('exit/',views.exit,name='exit'),
]
中间件设置
MIDDLEWARE = [
'django.middleware.security.SecurityMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',#处理登录状态 session
'django.middleware.common.CommonMiddleware',
'django.middleware.csrf.CsrfViewMiddleware', #防跨域攻击
'django.contrib.auth.middleware.AuthenticationMiddleware',#用户对象
'django.contrib.messages.middleware.MessageMiddleware', #消息处理
'django.middleware.clickjacking.XFrameOptionsMiddleware',
#'FM_demo.mymiddleware.MyMidd',
'FM_demo.mymiddleware.UserLogin',
]
index.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>首页</title>
</head>
<body>
欢迎:{{ username }}<br>
{{ name }}<br>
<a href="{% url 'dom:login' %}">登录</a><br>
<a href="{% url 'dom:exit' %}">退出</a>
</body>
</html>
login.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>登录</title>
</head>
<body>
<form action="" method="post">
{% csrf_token %}
<input type="text" name="username" placeholder="请输入用户名"><br>
<input type="password" name="password" placeholder="请输入密码"><br>
<input type="text" name="message" placeholder="请输入验证码"><br>
<input type="text" name="email" placeholder="请输入邮箱"><br>
<input type="date" name="birthday" placeholder="请输入出生日期"><br>
<input type="submit" value="登录">
</form>
</body>
</html>
效果演示:
基本案例就实现了