aop注解开发:步骤
- 扫描器扫描对象放入spring容器
- 开启注解支持标签
-
<!--自动扫描,创建对象--> <context:component-scan base-package="com.colin.mybatis.aop"/> <!--开启aop注解支持--> <aop:aspectj-autoproxy/>
-
- 对象加上@Component注解
- 切面类加上@Aspect注解
- 切入点之前增加:@Before(value = "execution(* com.colin.mybatis.aop.MyMath.*(..))")
- 切入点之后增加:@After(value = "execution(* com.colin.mybatis.aop.MyMath.*(..))")
- 切入点环绕:@Around(value = "execution(* com.colin.mybatis.aop.MyMath.*(..))")
- 切入点赋值过程:@AfterReturning(value = "execution(* com.colin.mybatis.aop.MyMath.*(..))",returning = "result")
- 切入点抛异常:@AfterThrowing(value = "execution(* com.colin.mybatis.aop.MyMath.*(..))", throwing = "e")
-
/** * @author yyc * @date 2022/7/8 */ @Component @Aspect public class AspectAutoProxy { /** * 方法执行前 */ @Before(value = "execution(* com.colin.mybatis.aop.MyMath.*(..))") public void before(JoinPoint joinPoint) { System.out.println(Arrays.toString(joinPoint.getArgs())); System.out.println("方法执行前"); } /** * 方法执行结束 */ @After(value = "execution(* com.colin.mybatis.aop.MyMath.*(..))") public void after() { System.out.println("方法执行结束"); } /** * 方法赋值过程 */ @AfterReturning(value = "execution(* com.colin.mybatis.aop.MyMath.*(..))",returning = "result") public void afterReturn(Object result) { System.out.println("这里是aop接到的返回值" + result.toString()); System.out.println("方法赋值过程"); } /** * 方法出现异常 */ @AfterThrowing(value = "execution(* com.colin.mybatis.aop.MyMath.*(..))", throwing = "e") public void afterThrow(Exception e) { System.out.println("方法出现异常" + e.getMessage()); } /** * 环绕 */ @Around(value = "execution(* com.colin.mybatis.aop.MyMath.*(..))") public Object around(ProceedingJoinPoint point) throws Throwable { System.out.println("环绕前"); Object o = point.proceed();//继续执行切入点,就是要增强的方法 System.out.println("环绕后"); return o; } }