电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

Mybatis Plugin攔截器開發過程詳解

瀏覽:118日期:2023-10-24 11:30:26

這篇文章主要介紹了Mybatis Plugin攔截器開發過程詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下

1.Plugin

MyBatis 允許使用插件來攔截的方法調用包括:

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

注意;可以通過插件攔截到這四個對象,修改參數等操作:

你必須要知道的類:

org.apache.ibatis.plugin.Plugin org.apache.ibatis.reflection.SystemMetaObject

2.使用步驟

實現 Interceptor 接口

三個方法執行順序

setProperties() plugin() intercept()

FirstIntercepter=====>setPropertiesFirstIntercepter====>pluginorg.apache.ibatis.executor.CachingExecutor@64485a47FirstIntercepter====>pluginorg.apache.ibatis.scripting.defaults.DefaultParameterHandler@2f0a87b3FirstIntercepter====>pluginorg.apache.ibatis.executor.resultset.DefaultResultSetHandler@4fcd19b3FirstIntercepter====>pluginorg.apache.ibatis.executor.statement.RoutingStatementHandler@2fd66ad3DEBUG 09-05 11:56:24,696 ==> Preparing: select * from employee where id=? (BaseJdbcLogger.java:159)FirstIntercepter:===>interceptDEBUG 09-05 11:56:24,722 ==> Parameters: 1(Integer) (BaseJdbcLogger.java:159)DEBUG 09-05 11:56:24,739 <== Total: 1 (BaseJdbcLogger.java:159)Employee [id=1, lastName=tom, gender=1, email=asd@qq.com, depid=null]

給你的攔截器簽名:

/*** 完成插件簽名:* 告訴MyBatis當前插件用來攔截哪個對象的哪個方法* type:要攔截的四大類型* method:攔截那個方法* args:這個方法的入參* */@Intercepts({@Signature(type=StatementHandler.class,method='parameterize',args=java.sql.Statement.class)})public class FirstIntercepter implements Interceptor

mybatis-cfg.xml中配置插件

這里注意配置plugins的標簽順序,以免出錯,在environments上面

<!-- plugins 插件的配置 實際上是使用:intercepter原理代理的 --><plugins><plugin interceptor='mybatis.intercepter.FirstIntercepter'><property name='param1' value='root'/><property name='param2' value='root'/></plugin></plugins>

3.多個插件的執行

多個插件依次生成目標對象的代理對象,層層包裹,先聲明的先包裹;形成代理鏈

可以理解為:初始化執行

執行log

FirstIntercepter=====>setProperties

MySecondIntercepter====>setProperties:{param1=root}FirstIntercepter====>pluginorg.apache.ibatis.executor.CachingExecutor@64485a47MySecondIntercepter====>plugin:org.apache.ibatis.executor.CachingExecutor@64485a47FirstIntercepter====>pluginorg.apache.ibatis.scripting.defaults.DefaultParameterHandler@2f0a87b3MySecondIntercepter====>plugin:org.apache.ibatis.scripting.defaults.DefaultParameterHandler@2f0a87b3FirstIntercepter====>pluginorg.apache.ibatis.executor.resultset.DefaultResultSetHandler@4fcd19b3MySecondIntercepter====>plugin:org.apache.ibatis.executor.resultset.DefaultResultSetHandler@4fcd19b3FirstIntercepter====>pluginorg.apache.ibatis.executor.statement.RoutingStatementHandler@2fd66ad3MySecondIntercepter====>plugin:org.apache.ibatis.executor.statement.RoutingStatementHandler@2fd66ad3DEBUG 09-05 12:07:01,928 ==> Preparing: select * from employee where id=? (BaseJdbcLogger.java:159)MySecondIntercepter====>intercept:public abstract void org.apache.ibatis.executor.statement.StatementHandler.parameterize(java.sql.Statement) throws java.sql.SQLExceptionFirstIntercepter:===>interceptDEBUG 09-05 12:07:01,954 ==> Parameters: 1(Integer) (BaseJdbcLogger.java:159)DEBUG 09-05 12:07:01,968 <== Total: 1 (BaseJdbcLogger.java:159)Employee [id=1, lastName=tom, gender=1, email=asd@qq.com, depid=null]

4.實現攔截修改參數

sql

<!-- Employee getSelectEmp(Integer id); --><select parameterType='java.lang.Integer'resultType='mybatis.bean.Employee'>select * from employee where id=#{id}</select>

這里我們攔截id:

由于ibatis中參數的聲明存在與 StatementHandler中所以注意簽名

@Intercepts({@Signature(type=StatementHandler.class,method='parameterize',args=java.sql.Statement.class)})

業務邏輯intercept方法中

/*** 1:業務邏輯處理的方法:*/@Overridepublic Object intercept(Invocation invocation) throws Throwable {//在這里可以進行業務邏輯修改System.out.println('FirstIntercepter:===>intercept'+invocation.getMethod()); MetaObject metaObject = SystemMetaObject.forObject(invocation.getTarget());//拿到target的元數據 StatementHandler==>ParameterHandler===>//DefaultParameterHandler==>>parameterObjectObject value = metaObject.getValue('parameterHandler.parameterObject');System.out.println('sql '+value.toString());//修改完sql語句要用的參數metaObject.setValue('parameterHandler.parameterObject', 2);Object object = invocation.proceed();return object;}

打印log,

可以看到原來入參為1,現在經過攔截器修改入參為2

DEBUG 09-05 12:36:23,387 ==> Preparing: select * from employee where id=? (BaseJdbcLogger.java:159)MySecondIntercepter====>intercept:public abstract void org.apache.ibatis.executor.statement.StatementHandler.parameterize(java.sql.Statement) throws java.sql.SQLExceptionFirstIntercepter:===>interceptpublic abstract void org.apache.ibatis.executor.statement.StatementHandler.parameterize(java.sql.Statement) throws java.sql.SQLExceptionsql 1DEBUG 09-05 12:36:23,418 ==> Parameters: 2(Integer) (BaseJdbcLogger.java:159)DEBUG 09-05 12:36:23,432 <== Total: 1 (BaseJdbcLogger.java:159)Employee [id=2, lastName=cat, gender=0, email=qwe@qq.com, depid=null]

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Mybatis 數據庫
相關文章:
主站蜘蛛池模板: 精密冲床,高速冲床等冲压设备生产商-常州晋志德压力机厂 | 郑州水质检测中心_井水检测_河南废气检测_河南中环嘉创检测 | 碎石机设备-欧版反击破-欧版颚式破碎机(站)厂家_山东奥凯诺机械 高低温试验箱-模拟高低温试验箱订制-北京普桑达仪器科技有限公司【官网】 | 吸污车_吸粪车_抽粪车_电动三轮吸粪车_真空吸污车_高压清洗吸污车-远大汽车制造有限公司 | 气动|电动调节阀|球阀|蝶阀-自力式调节阀-上海渠工阀门管道工程有限公司 | 昆明网络公司|云南网络公司|昆明网站建设公司|昆明网页设计|云南网站制作|新媒体运营公司|APP开发|小程序研发|尽在昆明奥远科技有限公司 | 福州仿石漆加盟_福建仿石漆厂家-外墙仿石漆加盟推荐铁壁金钢(福建)新材料科技有限公司有保障 | Type-c防水母座|贴片母座|耳机接口|Type-c插座-深圳市步步精科技有限公司 | LCD3D打印机|教育|桌面|光固化|FDM3D打印机|3D打印设备-广州造维科技有限公司 | 真空上料机(一种真空输送机)-百科 | 电缆接头_防水接头_电缆防水接头_防水电缆接头_上海闵彬 | 广东健伦体育发展有限公司-体育工程配套及销售运动器材的体育用品服务商 | 蔬菜清洗机_环速洗菜机_异物去除清洗机_蔬菜清洗机_商用洗菜机 - 环速科技有限公司 | 氧氮氢联合测定仪-联测仪-氧氮氢元素分析仪-江苏品彦光电 | 动库网动库商城-体育用品专卖店:羽毛球,乒乓球拍,网球,户外装备,运动鞋,运动包,运动服饰专卖店-正品运动品网上商城动库商城网 - 动库商城 | 冷却塔降噪隔音_冷却塔噪声治理_冷却塔噪音处理厂家-广东康明冷却塔降噪厂家 | 小型单室真空包装机,食品单室真空包装机-百科 | 软瓷_柔性面砖_软瓷砖_柔性石材_MCM软瓷厂家_湖北博悦佳软瓷 | EPK超声波测厚仪,德国EPK测厚仪维修-上海树信仪器仪表有限公司 | 砂石生产线_石料生产线设备_制砂生产线设备价格_生产厂家-河南中誉鼎力智能装备有限公司 | 上海公众号开发-公众号代运营公司-做公众号的公司企业服务商-咏熠软件 | 橡胶弹簧|复合弹簧|橡胶球|振动筛配件-新乡市永鑫橡胶厂 | 电磁流量计厂家_涡街流量计厂家_热式气体流量计-青天伟业仪器仪表有限公司 | 拉力机-万能试验机-材料拉伸试验机-电子拉力机-拉力试验机厂家-冲击试验机-苏州皖仪实验仪器有限公司 | 彭世修脚_修脚加盟_彭世修脚加盟_彭世足疗加盟_足疗加盟连锁_彭世修脚技术培训_彭世足疗 | 欧景装饰设计工程有限公司-无锡欧景装饰官网 | 消泡剂-水处理消泡剂-涂料消泡剂-切削液消泡剂价格-东莞德丰消泡剂厂家 | 不锈钢电动球阀_气动高压闸阀_旋塞疏水调节阀_全立阀门-来自温州工业阀门巨头企业 | 水平垂直燃烧试验仪-灼热丝试验仪-漏电起痕试验仪-针焰试验仪-塑料材料燃烧检测设备-IP防水试验机 | 软文发布-新闻发布推广平台-代写文章-网络广告营销-自助发稿公司媒介星 | 生产加气砖设备厂家很多,杜甫机械加气砖设备价格公道 | 油液红外光谱仪-油液监测系统-燃油嗅探仪-上海冉超光电科技有限公司 | 新中天检测有限公司青岛分公司-山东|菏泽|济南|潍坊|泰安防雷检测验收 | BAUER减速机|ROSSI-MERSEN熔断器-APTECH调压阀-上海爱泽工业设备有限公司 | 螺旋丝杆升降机-SWL蜗轮-滚珠丝杆升降机厂家-山东明泰传动机械有限公司 | LCD3D打印机|教育|桌面|光固化|FDM3D打印机|3D打印设备-广州造维科技有限公司 | 包装设计公司,产品包装设计|包装制作,包装盒定制厂家-汇包装【官方网站】 | 斗式提升机,斗式提升机厂家-淄博宏建机械有限公司 | 伶俐嫂培训学校_月嫂培训班在哪里报名学费是多少_月嫂免费政府培训中心推荐 | 武汉印刷厂-不干胶标签印刷厂-武汉不干胶印刷-武汉标签印刷厂-武汉标签制作 - 善进特种标签印刷厂 | 泥浆在线密度计厂家-防爆数字压力表-膜盒-远传压力表厂家-江苏大亚自控设备有限公司 |