zoukankan      html  css  js  c++  java
  • 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, 开始返回。

  • 相关阅读:
    IP地址和MAC地址,以及arp攻击
    可爱的老婆
    win7 homebasic下,.net2008 连接oracle,提示错误OCIEnvCreate 失败,返回代码为 1,但错误消息文本不可用
    检讨
    数据库索引
    PB调用C#编写的DLL
    用c#开发可供PB调用的COM组件
    关于excel取消科学计数法的问题
    按键码对照
    JSONP学习资料
  • 原文地址:https://www.cnblogs.com/momo8238/p/7719301.html
Copyright © 2011-2022 走看看