MyBatis攔截器:給參數(shù)對(duì)象屬性賦值

MyBatis攔截器:給參數(shù)對(duì)象屬性賦值

策勒ssl適用于網(wǎng)站、小程序/APP、API接口等需要進(jìn)行數(shù)據(jù)傳輸應(yīng)用場(chǎng)景,ssl證書未來(lái)市場(chǎng)廣闊!成為成都創(chuàng)新互聯(lián)公司的ssl證書銷售渠道,可以享受市場(chǎng)價(jià)格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:028-86922220(備注:SSL證書合作)期待與您的合作!

  1 package com.development;  2   3 import java.lang.reflect.InvocationTargetException;  4 import java.util.Date;  5 import java.util.Map;  6 import java.util.Properties;  7   8 import org.apache.commons.beanutils.BeanUtils;  9 import org.apache.ibatis.executor.Executor; 10 import org.apache.ibatis.mapping.MappedStatement; 11 import org.apache.ibatis.mapping.SqlCommandType; 12 import org.apache.ibatis.plugin.Interceptor; 13 import org.apache.ibatis.plugin.Intercepts; 14 import org.apache.ibatis.plugin.Invocation; 15 import org.apache.ibatis.plugin.Plugin; 16 import org.apache.ibatis.plugin.Signature; 17  18 /** 19  * 攔截器作用:給各實(shí)體對(duì)象在增加、修改時(shí),自動(dòng)添加操作屬性信息。 20  */ 21 @Intercepts({@Signature(type = Executor.class, method = "update", args = {MappedStatement.class, Object.class }) }) 22 public class OpeInfoInterceptor implements Interceptor 23 { 24  25     public Object intercept(Invocation invocation) throws Throwable 26     { 27         Object[] args = invocation.getArgs(); 28  29         System.out.println("-----------參數(shù)攔截---------------------------------------------------"); 30         System.out.println("02 當(dāng)前線程ID:"+Thread.currentThread().getId()); 31         //遍歷處理所有參數(shù),update方法有兩個(gè)參數(shù),參見Executor類中的update()方法。 32         for(int i=0;i<args.length;i++) 33         { 34             Object arg=args[i]; 35             String className=arg.getClass().getName(); 36             System.out.println(i + " 參數(shù)類型:"+className); 37              38             //第一個(gè)參數(shù)處理。根據(jù)它判斷是否給“操作屬性”賦值。 39             if(arg instanceof MappedStatement) 40             {//如果是第一個(gè)參數(shù) MappedStatement 41                 MappedStatement ms = (MappedStatement)arg; 42                 SqlCommandType sqlCommandType = ms.getSqlCommandType(); 43                 System.out.println("操作類型:"+sqlCommandType); 44                 if(sqlCommandType == SqlCommandType.INSERT || sqlCommandType==SqlCommandType.UPDATE) 45                 {//如果是“增加”或“更新”操作,則繼續(xù)進(jìn)行默認(rèn)操作信息賦值。否則,則退出 46                     continue; 47                 } 48                 else 49                 { 50                     break; 51                 } 52             } 53              54             //第二個(gè)參數(shù)處理。(只有第二個(gè)程序才能跑到這) 55             if (arg instanceof Map) 
 56             {//如果是map,有兩種情況:(1)使用@Param多參數(shù)傳入,由Mybatis包裝成map。(2)原始傳入Map 57                 System.out.println("這是一個(gè)包裝過(guò)的類型!"); 58                 Map map=(Map)arg; 59                 for (Object obj : map.values()) 
 60                 {  
 61                     setProperty(obj); 62                 } 
 63             } 64             else 65             {//原始參數(shù)傳入 66                 setProperty(arg); 67             } 68              69         } 70  71         return invocation.proceed(); 72  73     } 74      75     /** 76      * 為對(duì)象的操作屬性賦值 77      * @param obj 78      */ 79     private void setProperty(Object obj) 80     { 81         try 82         { 83             //TODO: 根據(jù)需要,將相關(guān)屬性賦上默認(rèn)值 84             BeanUtils.setProperty(obj, "createrUsername", "張三"); 85             BeanUtils.setProperty(obj, "createDT", new Date()); 86         } 87         catch (IllegalAccessException e) 88         { 89             e.printStackTrace(); 90         } 91         catch (InvocationTargetException e) 92         { 93             e.printStackTrace(); 94         } 95     } 96  97     public Object plugin(Object target) 98     { 99         return Plugin.wrap(target, this);100     }101 102     public void setProperties(Properties properties)103     {104 105     }106 107 }

MyBatis攔截器:給參數(shù)對(duì)象屬性賦值

當(dāng)前題目:MyBatis攔截器:給參數(shù)對(duì)象屬性賦值
網(wǎng)頁(yè)URL:http://muchs.cn/article42/iiosec.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供營(yíng)銷型網(wǎng)站建設(shè)、電子商務(wù)、面包屑導(dǎo)航、動(dòng)態(tài)網(wǎng)站、企業(yè)建站、網(wǎng)站設(shè)計(jì)公司

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都做網(wǎng)站