django中间件

中间件

Django中的中间件是一个轻量级、底层的插件系统,可以介入Django的请求和响应处理过程,修改Django的输入或输出。中间件的设计为开发者提供了一种无侵入式的开发方式,增强了Django框架的健壮性,其它的MVC框架也有这个功能,名称为IoC。

Django在中间件中预置了五个方法,这五个方法的区别在于不同的阶段执行,对输入或输出进行干预,方法如下:

1)初始化:无需任何参数,服务器响应第一个请求的时候调用一次,用于确定是否启用当前中间件。

def __init__(self):
    pass

2)处理请求前:在每个请求上,request对象产生之后,url匹配之前调用,返回None或HttpResponse对象。

def process_request(self, request):
    pass

3)处理视图前:在每个请求上,url匹配之后,视图函数调用之前调用,返回None或HttpResponse对象。

def process_view(self, request, view_func, *view_args, **view_kwargs):
    pass

4)处理响应后:视图函数调用之后,所有响应返回浏览器之前被调用,在每个请求上调用,返回HttpResponse对象。

def process_response(self, request, response):
    pass

5)异常处理:当视图抛出异常时调用,在每个请求上调用,返回一个HttpResponse对象。

def process_exception(self, request,exception):
    pass

请添加图片描述
比如这个中间件就是防止视图函数访问EXCLUDE_IPS存储的ip

from django.http import  HttpResponse
from django.utils.deprecation import MiddlewareMixin

class BlockedIPSMiddleware(MiddlewareMixin):
    EXCLUDE_IPS = ['127.0.0.1']

    # 中间件,视图函数运行前会运行中间件的函数
    # 这个中间件process_view
    def process_view(self,request, view_func ,*view_args , **view_kwargs):
        '''视图函数调用之前用'''
        user_ip = request.META['REMOTE_ADDR']
        if user_ip in BlockedIPSMiddleware.EXCLUDE_IPS:
            return HttpResponse('<h1>禁止访问</h1>')

class TestMiddleware(MiddlewareMixin):
    '''中间件类'''
    def __init(self):
        '''服务器重启之后,接收第一个请求时调用'''
        print('__init__')


    def process_request(self , request):
        '''产生request对象之后url匹配之前调用'''
        print('__process_request__')
        # 后续过程就没了
        # return HttpResponse('request')

    def process_view(self,request, view_func ,*view_args , **view_kwargs):
        '''url匹配之后,视图函数调用之前用'''
        print('__process_view__')

    def process_reponse(self, request , response):
        '''视图函数调用之后,内容返回浏览器之前'''
        print('__process_response__')
        return response

    def process_exception(self, request, exception):
        '''视图函数发生异常时调用'''
        print('process_exception')

它还可以用此装饰器解决

# 禁止用户访问的装饰器
EXCLUDE_IPS = ['127.0.0.2']
def blocked_ips(view_func):
    def wrapper(request, *view_args, **view_kwargs):
        # 获取浏览器端的ip地址
        user_ip = request.META['REMOTE_ADDR']
        if user_ip in EXCLUDE_IPS:
            return HttpResponse('<h1>禁止访问</h1>')
        else:
            return view_func(request, *view_args, **view_kwargs)
    return wrapper


@blocked_ips
def static_test(request):
    '''静态文件'''
    return render(request, 'booktest/static_test.html')

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值