通过Spring AOP 拦截 SQL

sql 的重要性,开发人员都很清除,并不是所有人和时刻都记得log sql ,为了不侵入原来已经写好的代码,亦为了将来可以方便移走log,采用spring 的AOP 来记录log 是件很有意义的事情。配置如下

  <bean id="theTracingBeforeAdvice" class="your.com.TracingBeforeAdvice"/>
  <bean class="org.springframework.aop.framework.autoproxy.BeanNameAutoProxyCreator">
  <property name="proxyTargetClass">
   <value>true</value>
  </property>

  <property name="interceptorNames">
   <list>
    <value>theTracingBeforeAdvice</value>
   </list>
  </property>
  <property name="beanNames">
   <list>
    <value>jdbcTemplate</value>
   </list>
  </property>
 </bean> 

 <bean id="jdbcTemplate"
  class="org.springframework.jdbc.core.JdbcTemplate">
  <property name="dataSource">
   <ref bean="dataSource" />
  </property>
 </bean>

 <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
  <property name="driverClassName" value="com.mysql.jdbc.Driver" />
  <property name="url" value="jdbc:mysql://localhost/mytest?useUnicode=true&amp;characterEncoding=utf-8" />
  <property name="username" value="root" />
  <property name="password" value="123456" />
  <property name="maxActive" value="100" />
  <property name="maxIdle" value="30" />
  <property name="maxWait" value="1000" />
  <property name="defaultAutoCommit" value="true" />
  <property name="removeAbandoned" value="true" />
  <property name="removeAbandonedTimeout" value="60" />
 </bean>

 有一点是很重要,spring 自动代理默认为接口,如果要代理类,需要在属性中指出,如上面的粗体

实现类

public class TracingBeforeAdvice implements MethodBeforeAdvice {
 private Logger logger = Logger.getLogger(TracingBeforeAdvice.class);
 public void before(Method m, Object[] args, Object target) throws Throwable {
  
  if (args != null) {
   logger.warn( target.getClass().getName() + "." + m.getName() );
   logger.warn(target.getClass().getName());
   
   if (args.length>0)
   {
    for(int i=0;i<args.length;i++)
    logger.warn( args[i]);
   }
  }
  
 }

}

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值