mybatis插件
mybatis源码写的极好,mybatis属于相对轻量级的orm框架,包含的功能并没有太多,较容易感受它的设计之美,所以用博客的方式进行记录;
mybatis插件在四处有使用到:
- 对sql入参 prameterHandler进行插件化处理
- 对sql出参result进行插件化处理
- 对stamentHandler进行插件化处理
- 对executor进行插件化处理;
mybatis的插件与平时所熟知的拦截器和过滤器类似,但设计并不相同,譬如:
- springmvc的HandlerInterceptor接口:拦截器实现类功能比较单一,并不参与调用链的调度,比较简单的一组接口的实现类;
- 过滤器:- 责任链模式,每个filter处理的时候入参中有chain对象,在执行完filter中的before后将控制权再交回给chain,由chain进行调度下一个before;然后调用链如图:
-
mybatis中的插件实现了Interceptor接口,其实现的方式属于装饰器模式;
-
将执行插件的target交给插件,插件返回一个代理对象;将该代理对象传给下一个插件,进行装饰
-
引入Plugin对象,将target和插件this传给Plugin
-
对target进行包装,将插件功能包装在代理对象中
-
对target进行包装,通过cglib对target进行代理;
-
传入的InvocationHandler是Plugin本身;
-
当调用target方法时,进入Plugin中的invoke方法;
-
这时才真正的对target方法有选择性的调用拦截器;
-
而拦截器中的实现只需要关注拦截逻辑的处理,因为target中的方法调用交给Invocation对象中调用;
单拿出mybatis中的插件进行表述的原因是,感觉设计的还是很有意思的;扩展性很好,同时有别于其它的拦截器和过滤器的实现;