Spring AOP機能

Aspect(切面):通知和切入点共同组成了切面:时间,地点和"故事"。

Pointcut(切入点):所谓切入点是指我们要对那些joinpoint进行拦截的定义:地点。

Advice(通知):通知定义了通知的内容及何时使用:时间,"故事"。

Advisor(方面):通知和切入点共同组成了方面:时间,地点和"故事"。

注意1:Advisor代表Spring中的Aspect,但是,与正常的Aspect不同,一个Advisor通常只持有一个Pointcut和一个Advice。而理论上,一个Aspect定义中可以有多个Pointcut和多个Advice,所以,我们可以认为Advisor是一种特殊的Aspect。

 注意2:Spring使用 <tx:advice>和 <aop:config> 用来配置事务,具体如何配置你可以参考Spring文档。

我解释一下(* com.evan.crm.service.*.*(..))中几个通配符的含义:

第一个 * —— 通配 任意返回值类型
第二个 * —— 通配 包com.evan.crm.service下的任意class
第三个 * —— 通配 包com.evan.crm.service下的任意class的任意方法
第四个 .. —— 通配 方法可以有0个或多个参数

综上:包com.evan.crm.service下的任意class的具有任意返回值类型、任意数目参数和任意名称的方法
<tx:advice/> 有关的设置

这一节里将描述通过 <tx:advice/> 标签来指定不同的事务性设置。默认的 <tx:advice/> 设置如下:

•事务传播设置是 REQUIRED

•隔离级别是 DEFAULT

•事务是 读/写

•事务超时默认是依赖于事务系统的,或者事务超时没有被支持。

•任何 RuntimeException 将触发事务回滚,但是任何 checked Exception 将不触发事务回滚

这些默认的设置当然也是可以被改变的。 <tx:advice/> 和 <tx:attributes/> 标签里的 <tx:method/> 各种属性设置总结如下:rollback-for/no-rollback-for:配置哪些异常可以导致/不导致回滚,在默认情况下,抛出RuntimeException或其子类将导致回滚,其它异常不会导致回滚 .

. <tx:method/> 有关的设置:
name                    是                与事务属性关联的方法名。  通配符(*)可以用来指定一批关联到相同的事务属性的方法。 如:'get*'、'handle*'、'on*Event'等等。
propagation         默认值-> REQUIRED  事务传播行为
isolation               默认值->DEFAULT       事务隔离级别
timeout                 默认值->-1                     事务超时的时间(以秒为单位)
read-only             默认值->false                事务是否只读?
rollback-for                                                  将被触发进行回滚的 Exception(s);以逗号分开。 如:'com.foo.MyBusinessException,ServletException'
no-rollback-for                                            不被触发进行回滚的 Exception(s);以逗号分开。

1.切面<bean id="test" class="jp.go.mic.ep.common.log.AspectLogging"></bean>
 <aop:config>
  <aop:pointcut id="blogicBeans1" expression="bean(*BLogic)" />
  <aop:pointcut id="serviceBeans1" expression="bean(*Service)" /> 
  <aop:aspect id="blogicServices" ref="test">   
   <aop:before method="logBeforeExecution" pointcut-ref="blogicBeans1"/>
   <aop:after method="logAfterExecution" pointcut-ref="blogicBeans1"/>
   <aop:after-throwing method="afterThrowing"   pointcut-ref="serviceBeans1" throwing="throwable"/>
  </aop:aspect>
 </aop:config>

package jp.go.mic.ep.common.log;

import jp.go.mic.ep.common.MessageConstants;
import jp.go.mic.ep.common.exception.BusinessException;

import org.aspectj.lang.JoinPoint;


public class AspectLogging {

 private Logger logger = LoggerFactory.getLogger(AspectLogging.class);
  
 public void blogicServices(){
  
 }
 
 public void logBeforeExecution(JoinPoint jp) {
         logger.log(MessageConstants.INFO_LOG, getLogMessage(jp, "START"));
  
 } 
    public void logAfterExecution(JoinPoint jp) {
          logger.log(MessageConstants.INFO_LOG, getLogMessage(jp, "END  "));
    }
    
    public void afterThrowing(BusinessException throwable) throws BusinessException{
         BusinessException bex = (BusinessException) throwable;
      logger.log(bex.getMessageID(), bex.getMessage(), throwable);
    }
 

 private String getLogMessage(JoinPoint jp, String msg) {
        String cName = jp.getTarget().getClass().getName();
        String mName = jp.getSignature().getName();
        StringBuffer temp = new StringBuffer();
        temp.append(cName);
        temp.append(".");
        temp.append(mName);
        temp.append(" - ");
        temp.append(msg);
        return temp.toString();
  }

}
2.方面

 

<tx:advice id="transactionInterceptor">
  <tx:attributes>
   <tx:method name="execute*" propagation="REQUIRED"
    rollback-for="java.lang.Exception" />
   <tx:method name="create*" propagation="REQUIRED"
    rollback-for="java.lang.Exception" />
   <tx:method name="update*" propagation="REQUIRED"
    rollback-for="java.lang.Exception" />
   <tx:method name="delete*" propagation="REQUIRED"
    rollback-for="java.lang.Exception" />
   <tx:method name="read*" propagation="REQUIRED"
    rollback-for="java.lang.Exception" />
  </tx:attributes>
 </tx:advice>

 

<aop:config>
  <aop:pointcut id="dlactionBeans"
   expression="
            execution(* org.apache.struts.actions.DownloadAction+.*(..))" />
  <aop:pointcut id="blogicBeans" expression="bean(*BLogic)" />
  <aop:pointcut id="serviceBeans" expression="bean(*Service)" />
  <aop:pointcut id="handlerBeans"
   expression="bean(*Handler) and (
            execution(* create*(..)) or
            execution(* update*(..)) or
            execution(* delete*(..)) or
            execution(* select*(..)) or
            execution(* execute*(..))
            )" />
  <aop:advisor pointcut-ref="dlactionBeans" advice-ref="transactionInterceptor" />
  <aop:advisor pointcut-ref="serviceBeans" advice-ref="transactionInterceptor" />
  <aop:advisor pointcut-ref="handlerBeans" advice-ref="transactionInterceptor" />
 </aop:config>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值