django框架进阶-中间件-长期维护
################## 为什么使用中间件? #######################
先说几个需求,
1,url的白名单,url=[ "XX"],这个里面是一个用户可以访问的url,这就是一个权限的概念了,
2,登陆之后才能访问某些url,之前使用的是装饰器,一个网站可能有一两千的url,这样加装饰器就不太好,所以使用中间件是非常不错的,
################## 什么是中间件? #######################
什么是中间件以及中间件的作用?
是一个轻量,低级别的插件系统,可以在全局范围内改变django的输入和输出,每一个中间件都负责做一些特定的功能。
也就是每一个请求都会走这个中间件, 注意:
因为改变的是全局,所以要谨慎使用,使用不当会影响性能, 浏览器到django框架的时候,
1,先经过一个wsgi,这个wsgi就是按照HTTP的协议的规则解析请求,
2,然后到中间件,
3,然后到url.py中,找对应关系
4,然后去views.py中,找到对应的函数,这个函数需要模板,需要数据,
5,然后可能去读一个模板templates,html页面,使用orm取数据,
django把数据渲染之后返回到浏览器,经过视图函数,经过url,经过wsgi,这个还需要按照HTTP的协议,进行解析,然后输出,
中间件就是经过wsgi之后就要经过中间件,这就是在全局影响django的请求和响应, 所以中间件,在wsgi之后,在url.py之前,在全局,操作django请求和响应的模块, 所以中间件多了不好,每次都经过,性能就会受到影响,
所以前面权限的例子,就是可以使用中间件的,这好像是一个过滤的功能一样,
比如验证是否登陆,如果没有登陆就提示登陆,登陆了就可以查看,这个也可以使用中间件
所以全网站级别的功能,就需要使用中间件, 这个是一个比较进阶的东西,你不知道不影响你写什么东西,
################## 自定义中间件 #######################
中间件可以定义五个方法,分别是:(主要的是process_request和process_response) process_request(self,request)
这个方法的执行顺序是按照在setting里面的设置,从上往下执行 process_view(self, request, view_func, view_args, view_kwargs)
执行顺序也是从上到下
什么时候执行的,这个比较特殊,是在url.py找到了对应的视图函数之后,在真正的视图函数执行之前,执行的, process_template_response(self,request,response)
这个方法的执行顺序是按照在setting里面的设置,从下往上执行
在视图函数执行完,在执行视图函数返回的render之前执行, process_exception(self, request, exception)
这个方法的执行顺序是按照在setting里面的设置,从下往上执行
是在自己写的视图函数抛出异常的时候,执行这个异常函数 process_response(self, request, response)
这个方法的执行顺序是按照在setting里面的设置,从下往上执行 以上方法的返回值可以是None或一个HttpResponse对象,如果是None,则继续按照django定义的规则向后继续执行,如果是HttpResponse对象,则直接将该对象返回给用户。 #################################### 这五个方法也是有执行顺序的
1,process_request
url.py
2,process_view
view.py
3,有异常就执行,process_exception
4,如果视图返回的响应对象中render方法,就执行process_template_response
5,process_response
只需要掌握process_request和process_response,其他的了解, 注意,
1,如果有6个中间件,执行顺序是先全部执行request,然后全部执行view,然后倒序全部执行response
2,如果第三个中间件的process_request有返回值,后面的中间件就断了,直接是执行1,2,3的view和3,2,1的response,剩下的456就不管了
3,但是如果第三个的process_view有返回值了,执行的是1,2,34,5,6的request,然后是1,2,3的view,但是是执行的6,5,4,3,2,1,的response,
################## 中间件自定义代码 #######################
from django.shortcuts import HttpResponse, redirect """
自定义的中间件
"""
from django.utils.deprecation import MiddlewareMixin # 定义一个可以访问的白名单
URL = ["/oo/", "/xx/", "/haha/"] class OoXx(MiddlewareMixin): # def process_request(self, request):
# print("这是我的第一个中间件:OoXx!")
# print(id(request))
# # print(request.path_info) # 获取访问的url的路径,
# # # 如果用户访问的URL 在 白名单里面
# # if request.path_info in URL:
# # return # 这是返回None,
# # # 否则 直接返回一个 响应 不走视图那部分了
# # else:
# # return HttpResponse("gun!")
#
# def process_response(self, request, response):
# """
# :param request: 是浏览器发来的请求对象
# :param response: 是视图函数返回的响应对象
# :return:
# """
# print("这是OOXX中间件里面的 process_response")
# # return response
# return HttpResponse("hahahaha")
#
# def process_view(self, request, view_func, view_args, view_kwargs):
# """
#
# :param request: 浏览器发来的请求对象
# :param view_func: 将要执行的视图函数的名字
# :param view_args: 将要执行的视图函数的位置参数
# :param view_kwargs: 将要执行的视图函数的关键字参数
# :return:
# """
# print("ooxx里面的process_view")
# print(view_func, type(view_func))
# return HttpResponse("ooxx:process_view") # def process_exception(self, request, exception):
# print(exception)
# print("ooxx里面的process_exception")
# return redirect("http://www.luffycity.com") # def process_template_response(self, request, response):
# print("ooxx 中的process_template_response")
# return response def process_request(self, request):
request.s10 = {"is_login": 1, "name": "s10"} class MD2(MiddlewareMixin): # def process_request(self, request):
# print("这是我的第二个中间件:MD2!")
# print(id(request))
#
# def process_response(self, request, response):
# print("这是MD2中间件里面的 process_response")
# return response
#
# def process_view(self, request, view_func, view_args, view_kwargs):
# print("MD2里面的process_view")
# print(view_func, type(view_func))
# return HttpResponse("md2:process_view") # def process_exception(self, request, exception):
# print(exception)
# print("MD2里面的process_exception") # def process_template_response(self, request, response):
# print("MD2 中的process_template_response")
# return response def process_request(self, request):
print(request.s10.get("is_login"))
################## 中间件版登录验证 #######################
中间件版的登录验证需要依靠session,所以数据库中要有django_session表。
urls.py
from django.conf.urls import url
from app01 import views urlpatterns = [
url(r'^index/$', views.index),
url(r'^login/$', views.login, name='login'),
] urls.py
view.py
from django.shortcuts import render, HttpResponse, redirect def index(request):
return HttpResponse('this is index') def home(request):
return HttpResponse('this is home') def login(request):
if request.method == "POST":
user = request.POST.get("user")
pwd = request.POST.get("pwd") if user == "andy" and pwd == "":
# 设置session
request.session["user"] = user
# 获取跳到登陆页面之前的URL
next_url = request.GET.get("next")
# 如果有,就跳转回登陆之前的URL
if next_url:
return redirect(next_url)
# 否则默认跳转到index页面
else:
return redirect("/index/")
return render(request, "login.html") views.py
login.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="x-ua-compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>登录页面</title>
</head>
<body>
<form action="{% url 'login' %}">
<p>
<label for="user">用户名:</label>
<input type="text" name="user" id="user">
</p>
<p>
<label for="pwd">密 码:</label>
<input type="text" name="pwd" id="pwd">
</p>
<input type="submit" value="登录">
</form>
</body>
</html> login.html
middlewares.py:
class AuthMD(MiddlewareMixin):
white_list = ['/login/', ] # 白名单
balck_list = ['/black/', ] # 黑名单 def process_request(self, request):
from django.shortcuts import redirect, HttpResponse next_url = request.path_info
print(request.path_info, request.get_full_path()) if next_url in self.white_list or request.session.get("user"):
return
elif next_url in self.balck_list:
return HttpResponse('This is an illegal URL')
else:
return redirect("/login/?next={}".format(next_url))
settings:
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',
'middlewares.AuthMD',
]
################################################
################################################
################################################
################################################
django框架进阶-中间件-长期维护的更多相关文章
- django框架进阶-分页-长期维护
################## 分页 ####################### 分页, django有自己内置的分页,但是功能不是很强大,所以自己写一个分页, web页面数据非常 ...
- django框架进阶-AJAX-长期维护
################## 预备知识---json ####################### 预备知识,json 什么是json?这是一种数据格式,和语言没有关系, 为什么 ...
- django框架进阶-admin-长期维护
############### django--admin的使用 ################ # django后台管理: # 第一步: # 在settings文件中修改语言和时区 L ...
- Django框架之中间件与Auth
Django框架之中间件与Auth模块一 cbv加装饰器 -先导入:from django.utils.decorators import method_decorator -1 可以在方法上加装饰器 ...
- 第三百一十六节,Django框架,中间件
第三百一十六节,Django框架,中间件 django 中的中间件(middleware),在django中,中间件其实就是一个类,在请求到来和结束后,django会根据自己的规则在合适的时机执行中间 ...
- Django框架 之 中间件
Django框架 之 中间件 浏览目录 中间件介绍 自定义中间件 中间件的执行流程 中间件版登录验证 一.中间件介绍 官方的说法:中间件是一个用来处理Django的请求和响应的框架级别的钩子.它是一个 ...
- python3开发进阶-Django框架的中间件的五种用法和逻辑过程
阅读目录 什么是中间件 中间件的执行流程 中间件的逻辑过程 一.什么是中间件? 官方的说法:中间件是一个用来处理Django的请求和响应的框架级别的钩子.它是一个轻量.低级别的插件系统,用于在全局范围 ...
- django框架之中间件
中间件简介 django 中的中间件(middleware),在django中,中间件其实就是一个类,在请求到来和结束后,django会根据自己的规则在合适的时机执行中间件中相应的方法. 在djang ...
- Django框架之中间件MiddleWare
Django中的中间件是一个轻量级.底层的插件系统,可以介入Django的请求和响应处理过程,修改Django的输入或输出.中间件的设计为开发者提供了一种无侵入式的开发方式,增强了Django框架的健 ...
随机推荐
- POJ 3659 再谈树形DP
Cell Phone Network Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 5325 Accepted: 188 ...
- 201771010123汪慧和《面向对象程序设计JAVA》第九周实验总结
一.理论部分 1.异常 (1)异常处理的任务就是将控制权从错误产生的地方转移给能够处理这种情况的错误处理器. (2)程序中可能出现的错误和问题:a.用户输入错误.b.设备错误.c.物理限制.d.代码错 ...
- vue图片查看器
vue 安装图片查看器插件安装cnpm install v-viewer引用 import 'viewerjs/dist/viewer.css' import Viewer from 'v-viewe ...
- MJJ玩磁铁
题目: Problem D: MJJ玩磁铁 Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 139 Solved: 9[Submit][Status][ ...
- 线性可分支持向量机与软间隔最大化--SVM(2)
线性可分支持向量机与软间隔最大化--SVM 给定线性可分的数据集 假设输入空间(特征向量)为,输出空间为. 输入 表示实例的特征向量,对应于输入空间的点: 输出 表示示例的类别. 我们说可以通过间隔最 ...
- POP3、SMTP和IMAP基础概念
POP3 POP3是Post Office Protocol 3的简称,即邮局协议的第3个版本,它规定怎样将个人计算机连接到Internet的邮件服务器和下载电子邮件的电子协议.它是因特网电子邮件的第 ...
- Is the MIME type 'image/jpg' the same as 'image/jpeg'?
https://stackoverflow.com/questions/33692835/is-the-mime-type-image-jpg-the-same-as-image-jpeg No, i ...
- IOC与AOP的理解
转自 https://blog.csdn.net/qq_38006047/article/details/80797386 1,理解“控制反转” 控制反转,也叫依赖注入,是面向对象编程中的一种设计理念 ...
- Go-map-字符串-指针-结构体
Maps 什么是 map ? 类似Python中的字典数据类型,以k:v键值对的形式. map 是在 Go 中将值(value)与键(key)关联的内置类型.通过相应的键可以获取到值. 如何创建 ma ...
- ccf-csp 任务调度,回溯算法我觉得ok神**wa了
#include<iostream> #include<string.h> #include<cmath> #define M 41 #define min(a,b ...