Day22-中间件
1.中间件,在其它程序中,有的叫管道,有的叫http handler。下面是原生的中间件
2.自己也可以写中间件
2.1 写中间件,新建文件夹Middle,新建m1.py
2.2 在setting里注册中间件,1个类就是1个中间件
2.3 做测试,看是否所有的请求过来时,都必须一一经过中间件。(写了一个test函数)
运行结果:说明test请求经过了所有的中间件,打印出001,002,003以后,才打印出no money.
2.4 当想拿返回值的时候,可以通过response函数。request里面存放的是客户端的所有数据,可以有request.GET,request.POST,request.method等方法。
m1.py
from django.utils.deprecation import MiddlewareMixin class Row1(MiddlewareMixin):
def process_request(self,request):
print('001')
def process_response(self,request,response):
print('第3个拿到返回值的人')
return response class Row2(MiddlewareMixin):
def process_request(self,request):
print('002')
def process_response(self,request,response):
print('第2个拿到返回值的人')
return response class Row3(MiddlewareMixin):
def process_request(self,request):
print('003')
def process_response(self,request,response):
print('第1个拿到返回值的人')
return response
运行test函数,打印结果:
2.5通过第一个中间件的时候,就可以判断一下,是否携带了请求头(CSRFtoken),如果没有带请求头的话,在第1步就可以终止了。
完善我们自己写的中间件。其实中间件就是一个普通的类。
m1.py
from django.utils.deprecation import MiddlewareMixin
from django.shortcuts import HttpResponse class Row1(MiddlewareMixin):
def process_request(self,request):
print('001')
def process_response(self,request,response):
print('第3个拿到返回值的人')
return response class Row2(MiddlewareMixin):
def process_request(self,request):
print('002')
return HttpResponse('你回去吧')
def process_response(self,request,response):
print('第2个拿到返回值的人')
return response class Row3(MiddlewareMixin):
def process_request(self,request):
print('003')
def process_response(self,request,response):
print('第1个拿到返回值的人')
return response
运行结果:
3. 整个请求的流程如下:1.10版本,到哪个中间件发生了阻断,就从哪个中间件返回。
注意process_request, process_response 2个函数名是写死的,不能变。
4. 加上process_view后,请求的整个流程就有了变化。
m1.py
from django.utils.deprecation import MiddlewareMixin
from django.shortcuts import HttpResponse class Row1(MiddlewareMixin):
def process_request(self,request):
print('001') def process_view(self,request,view_func,view_func_args,view_func_kwargs):
print('张欣彤1') def process_response(self,request,response):
print('第3个拿到返回值的人')
return response class Row2(MiddlewareMixin):
def process_request(self,request):
print('002')
#return HttpResponse('你回去吧') def process_view(self,request,view_func,view_func_args,view_func_kwargs):
print('张欣彤2') def process_response(self,request,response):
print('第2个拿到返回值的人')
return response class Row3(MiddlewareMixin):
def process_request(self,request):
print('003') def process_view(self, request, view_func, view_func_args, view_func_kwargs):
print('张欣彤3') def process_response(self,request,response):
print('第1个拿到返回值的人')
return response
结果:
请求流程:
5. 解析process_view函数的意义
def process_view(self,request,view_func,view_func_args,view_func_kwargs):
view_func:指的就是URL中对应的那个函数,在这里指test函数
view_func_args:对应test函数中接收的参数,对应的URL如下:url(r'^test/(\d+)$', views.test), def test(request,nid)
view_func_kwargs:对应test函数中接收的字典,对应的URL如下:url(r'^test/(?P<nid>\d+)$', views.test), def test(request,nid)
流程更新如下:
6. def process_exception(self,request,exception): 这个函数一般情况下不执行,只有在出错时才执行。指的是异常信息
7. def process_template_response (self,request,response): 默认情况下也不执行,
如果views中的函数返回的对象中,具有render方法,那这个函数就会执行了。 如下示例:因为有render方法,所以函数确实执行了。
函数粘贴:
urls.py
from django.conf.urls import url
from django.contrib import admin
from app01 import views urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^login/$', views.login),
url(r'^index/$', views.index),
url(r'^logout/$', views.logout),
url(r'^test/(\d+)$', views.test),
]
views.py
from django.shortcuts import render,HttpResponse,redirect
# Create your views here.
def login(request):
if request.method=='GET':
return render(request,'login.html')
elif request.method=='POST':
user=request.POST.get('user')
pwd=request.POST.get('pwd')
if user=='root' and pwd=='123':
#生成随机字符串,写到浏览器cookie中,保存在session中。在随机字符串对应的字典中设置相关内容...
# 在session里面设置值
request.session['username']=user
request.session['is_login']=True
if request.POST.get('remember',None)=='1':
#设置超时时间
request.session.set_expiry(10)
return redirect('/index/')
else:
return render(request,'login.html')
def index(request):
#获取当前用户的随机字符串
#根据随机字符串获取对应的信息
#去session中获取值,如果登录成功,显示用户名
if request.session.get('is_login',None):
#return HttpResponse(request.session['username'])
return render(request,'index.html',{'username':request.session['username']})
else:
return HttpResponse('滚')
def logout(request):
request.session.clear()
return redirect('/login/') class Foo:
def render(self):
return HttpResponse('OK') def test(request,nid):
print('no money')
return Foo()
#return HttpResponse('OK')
m1.py
from django.utils.deprecation import MiddlewareMixin
from django.shortcuts import HttpResponse class Row1(MiddlewareMixin):
def process_request(self,request):
print('001') def process_view(self,request,view_func,view_func_args,view_func_kwargs):
print('张欣彤1') def process_response(self,request,response):
print('第3个拿到返回值的人')
return response class Row2(MiddlewareMixin):
def process_request(self,request):
print('002')
#return HttpResponse('你回去吧') def process_view(self,request,view_func,view_func_args,view_func_kwargs):
print('张欣彤2') def process_response(self,request,response):
print('第2个拿到返回值的人')
return response class Row3(MiddlewareMixin):
def process_request(self,request):
print('003') def process_view(self, request, view_func, view_func_args, view_func_kwargs):
print('张欣彤3') def process_response(self,request,response):
print('第1个拿到返回值的人')
return response def process_template_response(self,request,response):
#如果views中的函数返回的对象中,具有render方法,那这个函数就会执行了。
print('----template-----response----')
return response
process_Request, 发出请求
process_view, 通过以后,就会达到view函数
process_response, 开始返回。
最新文章
- SQL中select与set的区别-转载
- [tmp] hu60@所有人插件
- ABAP宏--Macros
- Android Studio tips2
- 前端见微知著JavaScript基础篇:你所不知道的apply, call 和 bind
- 在CentOS 7 上搭建LAMP
- MSYS2 安装和配置
- ASP.NET MVC- Area 使用
- MongoDB入门三步曲1--安装、基本操作
- java学习一目了然&mdash;&mdash;异常必知
- 【Eclipse】Failed to load JavaHL Library
- IOS多线程加锁
- java反射机制(2)
- onmousedown活用之碰撞效果
- Django—urls系统:urls基础
- JavaScript根据经纬度获取距离信息
- Linux 桌面玩家指南:11. 在同一个硬盘上安装多个 Linux 发行版以及为 Linux 安装 Nvidia 显卡驱动
- X-Pack for the Elastic Stack [6.2] &#187; Securing the Elastic Stack &#187;Setting Up User Authentication
- 02-centOS6.7安装
- 【RL前沿】深度强化学习的最新进展 by 2017.12.12
热门文章
- 使用Chrome控制台进行3D模型编辑的尝试
- Unity中容易被忽略的小技巧
- 使用FFMPEG 压缩png图片 与tinypng压缩结果对比
- linux安装nginx并配置负载均衡
- sprint2(第四天)
- java 框架 面试 2
- mabatis报错 Result Maps collection already contains value for gamedataserver.dao.one.ChargeRecordMapper.BaseResultMap
- 2016011998+sw
- 用jar包运行带GUI的java游戏
- Tensorflow踩坑之tf.nn.bidirectional_dynamic_rnn()报错 “ValueError: None values not supported.”