编写一个中间件

本文涉及的产品
Serverless 应用引擎 SAE,800核*时 1600GiB*时
注册配置 MSE Nacos/ZooKeeper,118元/月
云原生网关 MSE Higress,422元/月
简介:

上次说到django的中间件,这次就来写一个。这次就是通过中间件来做一个类似于日志的记录。


一、创建一个中间件目录与中间件文件

    中间件目录是Middle,log.py是中间件文件

wKioL1lJ3CKwBuMfAAANjSryovs678.png

现在来看看log.py文件:

wKiom1lJ3IGRD6k0AACDpeM3Zkc696.png

也许写的比较low,就是想要记录一下访问项目的时间,ip,请求方式,请求url,返回的状态码。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
class  Row1(MiddlewareMixin):
     def  process_request( self ,request):
         if  request.META.has_key( 'HTTP_X_FORWARDED_FOR' ):
             ip  =  request.META[ 'HTTP_X_FORWARDED_FOR' ]
         else :
             ip  =  request.META[ 'REMOTE_ADDR' ]
         =  request.path_info
         =  request.method
         subfolder  =  time.strftime( "%Y%m%d" )
         =  str (time.strftime( '%Y-%m-%d %H:%M:%S' ,time.localtime(time.time())))
         path  =  str ( 'log/'  +  subfolder  + '.log' )
         =  open (path, 'a+' )
         f.write(  '[' + +  ']' + '\t' +  +  '\t' +  +  '\t' +  ip  + '\t' )
         f.close()
     def  process_response( self ,request,response):
         subfolder  =  time.strftime( "%Y%m%d" )
         path  =  str ( 'log/'  +  subfolder  +  '.log' )
         status  =  str (response.status_code)
         =  open (path,  'a+' )
         f.write(status  +  '\n' )
         f.close()
         return  response

当然,要创建这个log目录:

wKiom1lJ33XiPHZBAAAceR1PZkw913.png


二、将这个中间件加入到django里

    想要这个中间件生效,还需要在django的settings.py文件里加入这个中间件配置,在MIDDLEWARE里加入'Middle.log.Row1',

wKiom1lJ3h7Amm_9AAA7_iqkIsQ058.png


三、测试

访问网站,在log目录下就会生成以日期为命名的.log文件,文件内容为:

wKiom1lJ4BHgtCDuAABFwWmxXB0870.png


四、总结

通过上面,我们可以编写各种你需要的中间件,来更完善你的项目,同样也避免了在views.py文件里写过多的代码。比如访问限制、黑白名单等等。。



本文转自 sykmiao 51CTO博客,原文链接:http://blog.51cto.com/syklinux/1940457,如需转载请自行联系原作者

相关文章
|
5月前
|
分布式计算 中间件 API
中间件应用集成的介绍
中间件应用集成在系统集成中扮演关键角色,通过中间件层连接和协调异构系统,促进通信与数据共享。它提供标准接口,简化集成过程,提升效率,实现业务流程统一。中间件类型多样,如集成、交易、工作量、门户中间件等,可根据需求定制,增强系统可用性、可扩展性,降低成本,助力企业提高效率和竞争力。
79 2
|
4月前
|
中间件 API 数据格式
中间件的工作流程
【6月更文挑战第15天】
79 8
|
2月前
|
安全 中间件 项目管理
Django 后端架构开发:分页器到中间件开发
Django 后端架构开发:分页器到中间件开发
35 1
|
3月前
|
消息中间件 中间件 Java
中间件选择合适的中间件
【7月更文挑战第8天】
64 2
|
4月前
|
消息中间件 安全 中间件
中间件中与中间件集成
【6月更文挑战第12天】
58 5
|
5月前
|
消息中间件 XML 监控
选择中间件功能和需求
【5月更文挑战第20天】
69 2
|
5月前
|
JSON 资源调度 JavaScript
中间件中加载和配置中间件
【5月更文挑战第18天】
52 2
|
5月前
|
运维 监控 中间件
中间件错误处理
【5月更文挑战第17天】
34 1
|
5月前
|
安全 中间件 数据处理
中间件在应用集成
中间件是应用集成的关键,它连接不同系统、平台和应用,解决兼容性问题,实现数据交换和功能互操作。主要应用包括数据集成、服务集成、消息传递、安全与权限管理。选择中间件需考虑兼容性、性能、可扩展性和安全性。中间件简化通信,提高系统性能和可靠性,助力企业实现应用高效协同和商业价值。
71 2
|
5月前
|
中间件
NetCore通过中间件判断接口是否存在 AllowAnonymousAttribute 特性
特性来判断一个接口是否被标记为允许匿名访问。以下是一个简单的中间件示例,用于在请求管道中检查接口是否被。.NET Core中,可以通过检查接口上的。在应用程序中使用此中间件,将其添加到。
73 0