Python-Django-Ajax进阶3

1 中间件

-是什么?

中间件顾名思义,是介于request与response处理之间的一道处理过程,相对比较轻量级,并且在全局上改变django的输入与输出。因为改变的是全局,所以需要谨慎实用,用不好会影响到性能

-怎么用:

 


-自定义中间件:

1 写一个类,继承MiddlewareMixin,
2 在类中写方法:
process_request
3 在settings中配置

from django.utils.deprecation import MiddlewareMixin

from django.shortcuts import render, HttpResponse


class mymiddleware1(MiddlewareMixin):
    def process_request(self, request):
        # print(request.path)
        # print(type(request))
        # request.aa='lqz'
        print('我是middle1的process_request方法')
        # 一旦returnHttpResponse对象,直接返回
        # return HttpResponse('我返回了')

    def process_response(self, request, response):
        # request就是请求对象
        # response就是响应对象
        print('我是middle1的process_response方法')
        # response.set_cookie('name','lqz')
        return response
    def process_view(self, request, callback, callback_args, callback_kwargs):
        # callback 是要执行的视图函数地址
        # callback_args是要执行的视图函数的位置参数(元组)
        # callback_kwargs是要执行的视图函数的关键字参数(字典)
        # print(type(callback))
        # print(callback_args)
        # print(callback_kwargs)
        # response=callback(request,*callback_args,**callback_kwargs)
        print('我是middle1的process_view方法')
        # 如果返回response,后面的process_view就不执行了,直接执行中间件的process_response方法
        # return response
    def process_exception(self, request, exception):
        #exception 异常对象
        print('我是m1的process_exception方法')

class mymiddleware2(MiddlewareMixin):
    def process_request(self, request):
        # print(request.path)
        # print(type(request))
        print('我是middle2的process_request方法')

    def process_response(self, request, response):
        print('我是middle2的process_response方法')
        return response

    def process_view(self, request, callback, callback_args, callback_kwargs):
        print('我是middle2的process_view方法')
    # 只有视图函数抛异常,才执行
    def process_exception(self, request, exception):
        print('我是m2的process_exception方法')
        print(str(exception))
        return HttpResponse('您的操作有误')

    def process_template_response(self, request, response):
        print('我是m2的process_template_response')
        return response

  

-5个方法(process_request,process_response)

-如果process_request方法返回HttpResponse的对象,请求直接返回,按中间件方法执行顺序往回走

2 csrf

xss攻击/csrf或xsrf跨站请求伪造
使用:中间件不注释,form表单中写{% csrf_token %}

posted @ 2019-01-23 20:38  逐梦~前行  阅读(210)  评论(0编辑  收藏  举报