步骤:

1) 先引入aop相关jar文件           (aspectj  aop优秀组件)

spring-aop-3.2.5.RELEASE.jar   【spring3.2源码】

aopalliance.jar                                        【spring2.5源码/lib/aopalliance】

aspectjweaver.jar                        【spring2.5源码/lib/aspectj】或【aspectj-1.8.2\lib】

aspectjrt.jar                                   【spring2.5源码/lib/aspectj】或【aspectj-1.8.2\lib】

注意: 用到spring2.5版本的jar文件,如果用jdk1.7可能会有问题。

需要升级aspectj组件,即使用aspectj-1.8.2版本中提供jar文件提供。

2) bean.xml中引入aop名称空间

3) 开启aop注解

4) 使用注解

@Aspect                            指定一个类为切面类
@Pointcut("execution(* cn.loaderman.e_aop_anno.*.*(..))") 指定切入点表达式 @Before("pointCut_()") 前置通知: 目标方法之前执行
@After("pointCut_()") 后置通知:目标方法之后执行(始终执行)
@AfterReturning("pointCut_()") 返回后通知: 执行方法结束前执行(异常不执行)
@AfterThrowing("pointCut_()") 异常通知: 出现异常时候执行
@Around("pointCut_()") 环绕通知: 环绕目标方法执行

package loaderman.e_aop_anno;

import org.aspectj.lang.ProceedingJoinPoint;
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 Aop { // 指定切入点表单式: 拦截哪些方法; 即为哪些类生成代理对象 @Pointcut("execution(* cn.loaderman.e_aop_anno.*.*(..))")
public void pointCut_(){
} // 前置通知 : 在执行目标方法之前执行
@Before("pointCut_()")
public void begin(){
System.out.println("开始事务/异常");
} // 后置/最终通知:在执行目标方法之后执行 【无论是否出现异常最终都会执行】
@After("pointCut_()")
public void after(){
System.out.println("提交事务/关闭");
} // 返回后通知: 在调用目标方法结束后执行 【出现异常不执行】
@AfterReturning("pointCut_()")
public void afterReturning() {
System.out.println("afterReturning()");
} // 异常通知: 当目标方法执行异常时候执行此关注点代码
@AfterThrowing("pointCut_()")
public void afterThrowing(){
System.out.println("afterThrowing()");
} // 环绕通知:环绕目标方式执行
@Around("pointCut_()")
public void around(ProceedingJoinPoint pjp) throws Throwable{
System.out.println("环绕前....");
pjp.proceed(); // 执行目标方法
System.out.println("环绕后....");
} }
package loaderman.e_aop_anno;

import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext; public class App { ApplicationContext ac =
new ClassPathXmlApplicationContext("cn/loaderman/e_aop_anno/bean.xml"); // 目标对象有实现接口,spring会自动选择“JDK代理”
@Test
public void testApp() {
IUserDao userDao = (IUserDao) ac.getBean("userDao");
System.out.println(userDao.getClass());//$Proxy001
userDao.save();
} // 目标对象没有实现接口, spring会用“cglib代理”
@Test
public void testCglib() {
OrderDao orderDao = (OrderDao) ac.getBean("orderDao");
System.out.println(orderDao.getClass());
orderDao.save();
} @Deprecated
// 共性问题:如果目标对象有实现接口,在从容器中获取目标对象的时候,只能通过接口接收对象。
public void testApp2() {
// 错误代码: 只能用接口接收
UserDao userDao = (UserDao) ac.getBean("userDao");
System.out.println(userDao.getClass());//$Proxy001
userDao.save();
} @Test
public void testGetObj() throws Exception {
OrderDao orderDao1 = (OrderDao) ac.getBean("orderDao");
OrderDao orderDao2 = (OrderDao) ac.getBean("orderDao"); System.out.println(orderDao1);
System.out.println(orderDao2); }
}
package loaderman.e_aop_anno;

public interface IUserDao {
void save();
}
package loaderman.e_aop_anno;

import org.springframework.context.annotation.Scope;
import org.springframework.stereotype.Component; /**
* 目标对象
*
*/
@Component // 加入容器
@Scope("prototype")
public class OrderDao{ public void save() {
System.out.println("-----核心业务:保存!!!------");
}
}
package loaderman.e_aop_anno;

import org.springframework.stereotype.Component;

/**
* 目标对象
*
*/
@Component // 加入容器
public class UserDao implements IUserDao{ @Override
public void save() {
System.out.println("-----核心业务:保存!!!------");
}
}
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:p="http://www.springframework.org/schema/p"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:aop="http://www.springframework.org/schema/aop"
xsi:schemaLocation="
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop.xsd"> <!-- 开启注解扫描 -->
<context:component-scan base-package="loaderman.e_aop_anno"></context:component-scan> <!-- 开启aop注解方式 -->
<aop:aspectj-autoproxy></aop:aspectj-autoproxy>
</beans>

最新文章

  1. Vmware怎样使用nat和桥接方式解决虚拟机联网问题
  2. python 出入任意多个参数
  3. Unity--截取屏幕任意区域
  4. HTML颜色编码
  5. 【PHP】新浪、淘宝的地区 API调用
  6. android-support-v7-appcompat的配置使用
  7. $.when().done().then()的用法
  8. 读书笔记 effective c++ Item 34 区分接口继承和实现继承
  9. 好IT男不能“淫”-谈IT人员目前普遍存在的“A情绪”
  10. Jquery EasyUI +Ajax +Json +一般处理程序 实现数据的前台与后台的交互 --- 善良公社项目
  11. 在自己的服务器上安装GitBook
  12. python查找读写文件
  13. linux python3 selenuim firefox
  14. vue 开发系列(八) 动态表单开发
  15. 关于oracle分组排序取值的问题
  16. Cocos2d-x移植android增加震动效果
  17. python 全栈开发:str(字符串)常用方法操作 、for 有限循环以及if 循环
  18. 对Prolog的感想和我写的一些教程
  19. Java设计原则—里氏替换原则(转)
  20. Firebird Procedure 带返回的存储过程

热门文章

  1. 我理解的epoll(二)——ET、LT的实例分析
  2. 将服务端select设置为非阻塞,处理更多业务
  3. (a ==1 &amp;&amp; a== 2 &amp;&amp; a==3) 有可能是 true 吗?
  4. Android利用json进行网络解析
  5. (三)wait()、notify()、notifyAll()
  6. IAR astyle代码美化
  7. C10K问题和多进程模型
  8. asyncio模块实现线程的嵌套和穿插
  9. setTimeout设置为0 为啥不能立马执行
  10. BZOJ 1022 / P4279 Luogu [SHOI2008]小约翰的游戏 (反Nim游戏) (Anti-SG)