当前位置: 首页 > news >正文

网站美化的目标文章优化关键词排名

网站美化的目标,文章优化关键词排名,临沂做网站,建站abc后台登录插件原理与开发 在 Mybatis总体执行流程 一文中简单的介绍了插件的初始化过程,本文将从源码的角度介绍一下mybatis的插件原理与简单开发实战。 插件原理 插件的注册和管理是通过InterceptorChain进行的,在创建Executor、StatementHandler、ParameterH…

插件原理与开发

在 Mybatis总体执行流程 一文中简单的介绍了插件的初始化过程,本文将从源码的角度介绍一下mybatis的插件原理与简单开发实战。

插件原理

插件的注册和管理是通过InterceptorChain进行的,在创建Executor、StatementHandler、ParameterHandler、ResultSetHandler对象时,会执行InterceptorChain的pluginAll方法

  public Object pluginAll(Object target) {// 遍历所有的插件for (Interceptor interceptor : interceptors) {// 执行插件的plugin方法,返回代理对象target = interceptor.plugin(target);}return target;}

拦截的原理,正是此时返回的代理对象,当调用目标方法时,执行的就是拦截器的intercept方法,从而实现拦截功能。

      // 执行插件的plugin方法,返回代理对象target = interceptor.plugin(target);

来到Interceptor接口的plugin方法:

  default Object plugin(Object target) {return Plugin.wrap(target, this);}

这是一个默认方法,一般不会重写它的逻辑。看其实现Plugin#wrap:

  public static Object wrap(Object target, Interceptor interceptor) {// 拿到拦截器的@Intercepts注解信息:key是要拦截的接口,value是要拦截的接口方法集合Map<Class<?>, Set<Method>> signatureMap = getSignatureMap(interceptor);// 这里的target,就是拦截的对象(Executor、StatementHandler、ParameterHandler、ResultSetHandler对象)Class<?> type = target.getClass();// 返回包含在signatureMap中的接口Class<?>[] interfaces = getAllInterfaces(type, signatureMap);// 存在被拦截的接口,返回一个代理对象if (interfaces.length > 0) {// 利用jdk动态代理生成代理对象:关注Plugin(实现了InvocationHandler接口)的invoke方法return Proxy.newProxyInstance(type.getClassLoader(),interfaces,new Plugin(target, interceptor, signatureMap));}// 接口没有被拦截,返回原始对象return target;}

可以看到,如果接口被拦截了,就会利用JDK动态代理生成代理对象,由于Plugin实现了InvocationHandler接口,所以其invoke方法会被执行:

  public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {try {// 拿到被拦截的接口方法集合Set<Method> methods = signatureMap.get(method.getDeclaringClass());// 判断当前执行的方法是否包含在其中,包含就是被拦截的方法if (methods != null && methods.contains(method)) {// 执行自定义拦截器的intercept方法,并将目标对象、方法、参数传入return interceptor.intercept(new Invocation(target, method, args));}// 否则直接执行原始方法return method.invoke(target, args);} catch (Exception e) {throw ExceptionUtil.unwrapThrowable(e);}}

插件开发

自定义插件需要:

  1. 实现Interceptor接口,重写intercept方法

  2. 使用@Intercepts和@Signature注解表明需要拦截哪些类的哪些方法

  3. 在配置文件中,添加插件配置

mybatis官网中,对此也有所描述:mybatis – MyBatis 3 | Configuration

根据官网描述,mybatis插件可以拦截的方法如下:

  • Executor (update, query, flushStatements, commit, rollback, getTransaction, close, isClosed)
  • ParameterHandler (getParameterObject, setParameters)
  • ResultSetHandler (handleResultSets, handleOutputParameters)
  • StatementHandler (prepare, parameterize, batch, update, query)

以下是我写的一个记录SQL及其耗时的拦截器,加深对拦截器的理解:

/*** @Author: qiuxinfa* @CreateTime: 2023-12-07  22:15* @Description: 自定义拦截器:打印SQL、统计SQL执行时间*/
@Intercepts({@Signature(type = StatementHandler.class,method = "batch",args = {Statement.class}),@Signature(type = StatementHandler.class,method = "update",args = {Statement.class}),@Signature(type = StatementHandler.class,method = "query",args = {Statement.class, ResultHandler.class}),
})
public class SqlLogPlugin implements Interceptor {@Overridepublic Object intercept(Invocation invocation) throws Throwable {// 获取执行的SQLString sql;Statement statement=(Statement) invocation.getArgs()[0];if(Proxy.isProxyClass(statement.getClass())){MetaObject metaObject= SystemMetaObject.forObject(statement);Object h = metaObject.getValue("h");if(h instanceof StatementLogger){RoutingStatementHandler rsh=(RoutingStatementHandler) invocation.getTarget();sql = rsh.getBoundSql().getSql();}else {PreparedStatementLogger psl=(PreparedStatementLogger) h;sql = psl.getPreparedStatement().toString();}}else{sql = statement.toString();}// 记录开始时间long start = System.currentTimeMillis();// 执行目标方法Object result = invocation.proceed();// 记录结束时间long end = System.currentTimeMillis();System.err.println("执行SQL ===> ");System.err.println(sql);System.err.println("统计SQL耗时 = " + (end - start) + "毫秒");System.err.println("返回结果 =======> " + result);return result;}
}

配置文件添加插件:

    <!-- 配置插件    --><plugins><plugin interceptor="com.qxf.plugin.SqlLogPlugin"></plugin></plugins>

配置之后,会打印执行的SQL语句及其耗时。

http://www.hkea.cn/news/307892/

相关文章:

  • 淄博市 网站建设报价郑州seo外包阿亮
  • 网络服务商是指什么网站优化排名工具
  • 网站优化的分析比较好的品牌策划公司有哪些
  • 国外比较好的资源网站电商运营推广是做什么的
  • 佛山房地产网站建设seo实战培训王乃用
  • 如何做可以赚钱的网站关键词如何快速排名
  • 深圳品牌做网站公司有哪些百度app推广
  • 重庆建设行业信息网站搜狗登录入口
  • 同仁行业网站建设报价北京做的好的seo公司
  • 陕西自助建站做网站郑州外语网站建站优化
  • 小型企业网站系统cilimao磁力猫最新版地址
  • 铁岭网站建设移动网站广东网站seo
  • 网站模板插件sem和seo
  • 用wordpress制作网站模板沈阳seo
  • 优化一个网站多少钱宜昌网站seo
  • 刚做的网站怎么才能搜索到枸橼酸西地那非片功效效及作用
  • 罗湖区网站公司专业模板建站
  • 哪有备案好的网站国产系统2345
  • 网站开发怎么让别人看到最新营销模式有哪些
  • ssm网站开发源码百度推广多少钱一个月
  • 手游门户网站建设appstore关键词优化
  • 齐河网站开发seo服务内容
  • 北京微信网站建设费用想卖产品怎么推广宣传
  • 网站上线的步骤厦门网站推广公司哪家好
  • 网站做app的软件有哪些百度一下你就知道下载
  • 界面设计的重要性百度seo关键词排名推荐
  • 股票做T网站直播营销
  • 北京手机网站建设公司排名技术优化seo
  • wordpress可爱的主题seo优化教程
  • 自己可以申请网站做外卖吗网站描述和关键词怎么写