最近公司项目需要做邮件发送功能,订单付款之后发送邮件,我一开始就考虑使用aop技术,尼玛,用的时候遇到各种蛋疼的问题,公司框架是ssm,在定义切点的时候,我将切点放在控制层action中,然后就发现各种问题,蛋疼一笔,没搞定,然后就使用了jms技术搞定了,之后又重新研究了一下,这次切点我没有放在action中,切点定义在service层中,这样就不会出现蛋疼的问题,目的也达到了。好了废话了好多,见代码。
//配置文件
<!-- start aop config -->
<context:component-scan base-package="com.maimai.aop"/>
<aop:aspectj-autoproxy proxy-target-class="true"/>
<!-- end -->
//切面
package com.maimai.aop;
import org.aspectj.lang.annotation.After;
import org.aspectj.lang.annotation.AfterReturning;
import org.aspectj.lang.annotation.AfterThrowing;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.aspectj.lang.annotation.Pointcut;
import org.springframework.stereotype.Component;
@Component
@Aspect
public class MailAop {
@Pointcut("execution(* com.maimai.engine.DealEngine.payByLeftMoney(..))")
public void perform(){
}
@AfterReturning("perform()")
public void methodAfter(){
System.out.println("............这是后置通知......");
}
/*
@Before("perform()")
public void myBeforeAdvice() {// 如果需要知道拦截的方法的信息,也可以需添加JoinPoint参数
System.out.println("............这是前置......");
}
// 最终置通知
@After("perform()")
public void doAfter() {
System.out.println("这是最终通知");
}
// 环绕通知
// @Around(value="pointcut1()")
@Around("perform()")
public void myAroundAdvice() {
// System.out.println("这是环绕通知:"+"sessionId="+session.getId() );
}
@AfterThrowing("perform()")
public void myAfterThrowingAdvice(){
System.out.println("----------------------------------------------------------------------啊,完蛋了报错了");
}
*/
}
//打印结果
2015-09-02 16:57:02,580 [http-8080-3] DEBUG [org.springframework.jdbc.datasource.DataSourceUtils] - Returning JDBC Connection to DataSource
2015-09-02 16:57:02,585 [http-8080-3] DEBUG [org.springframework.beans.factory.support.DefaultListableBeanFactory] - Returning cached instance of singleton bean 'mailAop'
............这是后置通知......
2015-09-02 16:57:03,502 [http-8080-3] DEBUG [org.springframework.jms.core.JmsTemplate] - Executing callback on JMS Session: ActiveMQSession {id=ID:wwsoft-PC-62768-1441184151155-0:2:1,started=false}