Hasor Dataway 实现原理
引言
最近搞接口可配置发布的服务,类似于Megic-Api,但是最近看到一个框架Hasor感觉这个框架很厉害,尝试分析一下他的实现原理,借鉴一波。
请求流程
先看简化流程图
粗略解释
- Hasor和Spring整合之后,请求的url 会进入RuntimeFilter2Controller这个过滤器,然后他就会从 Mapping[] (实际上就是URL和 HttpMethod,以及处理方式的缓存)找到对应的请求对应的处理方法。
- 调用处理方法进行处理
- 将结果返回。
详细分析
- 项目启动的时候会在WebHasorConfiguration内的addController方法内部初始化 RuntimeFilter2Controller 然后将 /** 路径注册到RequestMappingHandlerMapping,该方法的处理函数为 RuntimeFilter2Controller.doHandler(),该方法一旦注册,以后的请求都会走这个doHandler方法进行处理。
- 这个 doHandler 方法实际上是处理一系列的过滤器,调用该方法就是调用整个过滤器链。
- 在RuntimeFilter过滤器处理的时候,会根据请求从Mapping信息中找到对应的 URL 请求方式如:(GET、PUT、POST)都匹配的Mapping信息。然后根据Mapping信息创建一个调用上下文信息,然后根据上下文信息进行请求,得到请求结果。
结束语
这是一种请求方式,也可以将请求的url不是通过过滤器寻找而是直接注册到RequestMappingHandlerMapping,类似于magic-api。总之各有优劣。