AOP使用详解
首先创建maven项目
添加依赖在pom.xml里
data:image/s3,"s3://crabby-images/969a9/969a9118e185e3e14c1f538541820bf9604b92e3" alt=""
创建三层结构和spring.xml文件,只要用到注解就得写扫描包在spring.xml里
data:image/s3,"s3://crabby-images/1ba5f/1ba5f84068fda479aad7c154c85bbbd7ae587bfe" alt=""
上篇文章的知识点总结
data:image/s3,"s3://crabby-images/4309c/4309c83925a47f0994fab8c06e9186e94b95dc25" alt=""
data:image/s3,"s3://crabby-images/7ca77/7ca77d6badff1f6eadeaa3cbb5ccd5ee2634d795" alt=""
data:image/s3,"s3://crabby-images/0685b/0685b6d78cf6def3ba1d340b37d98b539a759fa9" alt=""
data:image/s3,"s3://crabby-images/4f08b/4f08b7d9d7bc095e610c2e6430619a40dfa2bd98" alt=""
对上篇文章excution详细解释
data:image/s3,"s3://crabby-images/a49cb/a49cb36cf955aa9003ffae8f1175fa38343147a6" alt=""
如果把前置通知修改成这个代表只有带有@Logger注解的才会生效
data:image/s3,"s3://crabby-images/1ea99/1ea99df83fca134098e1ed74ed1dacc8e8bdf50c" alt=""
data:image/s3,"s3://crabby-images/bb865/bb86529979d25b82579902885fcc6c7cd30864b3" alt=""
合并注解的方法用&&
data:image/s3,"s3://crabby-images/39d54/39d54b99e60a8d86a1f4b6586e4af3431db68aaf" alt=""
在before或者其他通知上加入JoinPoint 可以获取执行的方法名字和参数使得日志更加有意义
data:image/s3,"s3://crabby-images/1698b/1698bbf413c205eb38c898371349604902cef4d3" alt=""
在后置放回通知上获取返回值的方法,在@AfterReturning里面添加returning="returnValue",方法里面添加参数Object returnValue
data:image/s3,"s3://crabby-images/e631c/e631cc530d4d7887cf5df50bf4e8bc4ef678f510" alt=""
在后置异常通知上添加throwing="ex",在方法上添加Exception ex,用来获取异常信息
data:image/s3,"s3://crabby-images/0ef5a/0ef5acb5a5e3c9ab573a6f3710fc2ed6ae3f78b9" alt=""
获取异常栈信息的方法如下图所示,就是下下图的红字信息打印到控制台上了
data:image/s3,"s3://crabby-images/0f948/0f948bc3ff972ce400f8da1fe2f319563859a30e" alt=""
data:image/s3,"s3://crabby-images/90e1d/90e1dde67f83a1193f13bbc5d7f224944748a0b5" alt=""
引用切点的方式让其他通知引用,意思是把execution放入到方法用,在其他的通知里引用此方法
data:image/s3,"s3://crabby-images/e191f/e191f1bb305062fa140b698110282f34bef06728" alt=""
可以获取bean方法上注解的信息,用@annotation加上通知里参数名字注意通知里的参数不能随便写
data:image/s3,"s3://crabby-images/fcd7c/fcd7cfab54de1925f68c24e10696b7cba488c80f" alt=""
data:image/s3,"s3://crabby-images/89751/89751caf6e42aef2b92b0793ea92ce04492c6555" alt=""
环绕通知的写法如下图所示
data:image/s3,"s3://crabby-images/675e7/675e71b4f404edc6c885de839adb7f0f2b78bcfb" alt=""
用基于xml和注解的方式开启AOP ref为要引用的增强类(日志类),id是expression写的内容的名字可以用id引用如pointcut
&;&意识是java里的&&,&;&是xml里的书写格式
@annotation(logger)是类中的注解
data:image/s3,"s3://crabby-images/f8876/f8876f9ee31ed62262aaa6dc64f6bb0b81a223ef" alt=""
Spring通知有哪些类型
@Before
@After
@AfterThrowing
@AfterReturning
@Around
解释基于XML SChema(xml)方式的切面实现
data:image/s3,"s3://crabby-images/f8876/f8876f9ee31ed62262aaa6dc64f6bb0b81a223ef" alt=""
解释基于注解的切面实现
整篇文章是基于注解的切面实现