MyBatis拦截器:给参数对象属性赋值

Posted 叶祖辉

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MyBatis拦截器:给参数对象属性赋值相关的知识,希望对你有一定的参考价值。

技术分享
  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  * 拦截器作用:给各实体对象在增加、修改时,自动添加操作属性信息。
 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("-----------参数拦截---------------------------------------------------");
 30         System.out.println("02 当前线程ID:"+Thread.currentThread().getId());
 31         //遍历处理所有参数,update方法有两个参数,参见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 + " 参数类型:"+className);
 37             
 38             //第一个参数处理。根据它判断是否给“操作属性”赋值。
 39             if(arg instanceof MappedStatement)
 40             {//如果是第一个参数 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                 {//如果是“增加”或“更新”操作,则继续进行默认操作信息赋值。否则,则退出
 46                     continue;
 47                 }
 48                 else
 49                 {
 50                     break;
 51                 }
 52             }
 53             
 54             //第二个参数处理。(只有第二个程序才能跑到这)
 55             if (arg instanceof Map) 
 56             {//如果是map,有两种情况:(1)使用@Param多参数传入,由Mybatis包装成map。(2)原始传入Map
 57                 System.out.println("这是一个包装过的类型!");
 58                 Map map=(Map)arg;
 59                 for (Object obj : map.values()) 
 60                 {  
 61                     setProperty(obj);
 62                 } 
 63             }
 64             else
 65             {//原始参数传入
 66                 setProperty(arg);
 67             }
 68             
 69         }
 70 
 71         return invocation.proceed();
 72 
 73     }
 74     
 75     /**
 76      * 为对象的操作属性赋值
 77      * @param obj
 78      */
 79     private void setProperty(Object obj)
 80     {
 81         try
 82         {
 83             //TODO: 根据需要,将相关属性赋上默认值
 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拦截器:给参数对象属性赋值的主要内容,如果未能解决你的问题,请参考以下文章

mybatis拦截器使用实践

自定义MyBatis拦截器

如何给动态对象dynamic 动态赋值

mybatis是如何将sql执行结果封装为目标对象并返回的?有哪些映射形式

Mybatis是如何将sql执行结果封装为目标对象并返回的?

struts2笔记