由于自己系统的需要,决定自己开发一个WebApi框架:
-
准备材料:
1:使用Python3,引用
from http.server import HTTPServer, BaseHTTPRequestHandler
2:分析请求,一般请求是http://xxxxx/user/login ,其中user是业务模块,login是该业务模块下的方法。
3:分析场景,生成环境是 前后端分离,所以 webapi 不用考虑 网页部分和 session的处理,只是
需要使用token方式来解决授权问题。
4:授权部分的拦截检测,处理所有请求,并在拦截器部分判断授权,但同时,也需要释放一些路径,比如gettoken 方法。
根据以上需求,我的设计思路是,根据请求的url解析出业务模块和方法模块,然后封装请求参数转换为json结构,进行处理。
如图是一个文件结构,main.py 是启动主文件,PythonRun.exe 是执行程序,Interceptor.py是拦截器,user.py ,home.py 是业务模块。
-
main.py 部分代码:
这里是启动服务,注意一点,这里需要使用多线程方式,否则性能受影响。
doWork方法是 具体的路由跳转,用来寻找具体的业务模块和方法,并执行。
getParam方法用来解析出get请求的参数和post请求的参数。
Corss_Origin方法是用来设定跨域访问。
SendReques方法用来对处理后的数据发送到前端。
Resquest类是请求处理类,相应get ,post请求。
ThHttpServer 类是服务多线程服务类。
-
Interceptor.py 拦截器代码
拦截器内有两个方法,拦截方法与检测路径例外方法。拦截方法用来获取 token 检测token ,每次http请求都将执行 Intercept方法 返回 true 是拦截返回404 错误。
不需要拦截的地址 添加到 paths变量内。
-
user.py 单元
如请求 地址 http://xxxxx/user/getdata
文件名称对应请求地址的 user ,getdata方法对应 user.py 下的 getdata方法 ,方法参数 params 是
get或 post 的参数 ,注意是 json结构。
前端我使用 hbuiler 开发,通过 Authorization 传递 token。
源码下载: Python版的WebApi框架下载