欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

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

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

策勒ssl適用于網(wǎng)站、小程序/APP、API接口等需要進(jìn)行數(shù)據(jù)傳輸應(yīng)用場(chǎng)景,ssl證書未來市場(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è)包裝過的類型!"); 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)頁URL:http://aaarwkj.com/article42/iiosec.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供營銷型網(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í)需注明來源: 創(chuàng)新互聯(lián)

成都做網(wǎng)站
亚洲欧美制服另类国产| 久久精品一区二区日韩| 国产国语激情对白在线| 开心五月六月婷婷在线 | 色偷偷91综合久久噜噜| 偷拍一区二区三区四区| 亚洲精品自拍一二三四区 | 亚洲人妻一区二区久久| 精品国产女同一区二区| 中文字幕中出亚洲精品| 给我搜一个一级黄色片| 91麻豆精品在线观看| 精品国产乱码一区二区三区四区| 日本道二区视频中文字幕| 欧美黄色一级在线免费观看| 一起草视频在线观看视频| 亚洲精品国产第一区| 亚洲国产熟女导航网站视频| 国产精品一区二区三区熟女| 成年人国产免费在线观看| 日韩欧美一区亚洲一区| 国产亚洲精品久久久9| 肥臀大屁股av在线播放| 亚洲精品av一区二区久久| 国产自拍在线视频精品| 亚洲国产精品一区二区av| 亚洲熟妇av乱码在线| 国产伦理在线观看一区二区| 欧美日韩伦理片在线观看| 欧美一区二区大香蕉视频| 亚洲激情人妻小说网| 亚洲精品中文字幕乱码| 亚洲激情av在线观看| 秋霞日韩欧美一区二区三区| 亚洲成av人在线播放| 欧美日韩国产精品综合| 欧美亚洲国产日韩在线高清| 凹凸国产精品熟女视频| 91麻豆国产在线视频| 99中文字幕国产精品| 97国产精品亚洲精品|