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>