Nice! KillTime又添新功能! 添加任意中间件!

前情提要

上次我们提到,Killtime框架确实中间件机制。写完上篇文章后,我就没了头绪,于是耽搁了几天。今晚,我又看了看已经写的代码,思考路由和中间件的关系,中间件到底怎么和路由联系起来! 原来的代码:

可以看出,原来的话,路由使用一个字典传递,直接暴露在外面。 现在呢?且看我的骚操作。

往期文章:

1,终于!我写出了自己的后端框架! - 掘金 (juejin.cn)

2,个人框架KillTime又添新功能!无痛获取表单参数! - 掘金 (juejin.cn)

解铃还须系铃人

既然我是通过dict传递参数,那为什么不能也传递函数、类! 靠!脑子wat了。干了!

可以看出,api方法可以传递路由、一个由中间件函数组成的列表和一个Handler类。传递进行KillTime类内部后,路由大概就是下面这个样子,我们只需要在handler内部处理这个dict就行,Perfect!

是不是想起了什么?没错!就是express框架,毕竟一开始我就想让他往这方面发展,现在终于实现了。 那么内部是怎么处理的呢?且往下看:

内部操作

这里是处理路由的核心代码,routes是Killtime的一个类型为dict的属性,数据由api()方法添加,内部结构就是上一张图片。 url_parse.path是处理过后的路径,比如 "/index"。上面代码的含义是:依次获取中间件列表、处理类,便利中间件列表,依次执行每个函数,如果这个中间件的返回值为False的话,直接退出for。 没成功执行一个中间件,mdw_count++, 最后计算执行的中间件个数是为传入的个数。如果是:执行处理类的get()方法(post请求就执行post方法),如果最后发现有中间件返回了False,则mdw_count < len(中间件列表), 那么就不会执行get方法,而是返回response.json()。

中间件定义

从山上一张图片可以看出,每个middleware传入了一个ctx,用来获取request数据,response的话已经写好了,直接调用response类即可。比如要做校验,可以使用Form类进行操作即可,传入ctx啥都有了。 最后返回True就可以让下一个中间件调用,如果有任何一个中间件返回了False, 那么处理类的get/post方法都不会调用。

说了这么多,不会是个细狗吧?

雄起!男人不能说不行!

雄起

先看代码,下面是中间件返回的False, 没法执行handler类的get方法:

效果:

修改中间件,返回True, 让handler类的get方法执行:

效果:

大功告成! 保命要紧,半夜1点了,睡了。。。

相关推荐
RFG20125 小时前
20、详解Dubbo框架:消费方如何动态获取服务提供方地址?【微服务架构入门】
java·人工智能·后端·微服务·云原生·架构·dubbo
瞎某某Blinder6 小时前
DFT学习记录[4] 电子和空穴的有效质量计算全流程
python·学习
TimberWill6 小时前
SpringBoot整合Srping Security实现权限控制
java·spring boot·后端
Liue612312316 小时前
基于YOLO11-C3k2-Faster-CGLU的路面落叶检测与识别系统实现
python
~央千澈~7 小时前
抖音弹幕游戏开发之第8集:pyautogui基础 - 模拟键盘操作·优雅草云桧·卓伊凡
网络·python·websocket·网络协议
占疏7 小时前
列表分成指定的份数
python
Gaosiy8 小时前
脑电python分析库MNE安装
python·脑机接口·脑电·mne
向量引擎小橙9 小时前
视觉艺术的“奇点”:深度拆解 Gemini-3-Pro-Image-Preview 绘画模型,看这只“香蕉”如何重塑 AI 创作逻辑!
人工智能·python·gpt·深度学习·llama
yaoxin5211239 小时前
324. Java Stream API - 实现 Collector 接口:自定义你的流式收集器
java·windows·python
独行soc9 小时前
2026年渗透测试面试题总结-24(题目+回答)
网络·python·安全·web安全·渗透测试·安全狮