1、通过bean配置(在xml文件配置)
说明该示例配置起日志记录功能
<aop:config>
<aop:aspect id="XX" ref="beanid指向具体配置的bean">
<aop:pointcut expression="切入点表达式" id="XX1"/>
<aop:after method="记录方法" pointcut-ref="XX1" />
</aop:aspect>
</aop:config>
2、使用AspectJ织入
在spring.xml配置文件中启用AspectJ :<aop:aspectj-autoproxy />
在你要用之为aop功能的类的头部加上@Aspect注解
需求:在不停止服务的情况下,通过上传一个jar包然后捕获某方法的异常进行处理
思路:
使用springaop实现
至于为什么要定义一个切入点到service包下面的所以方法,感兴趣的可以研究一下springAop的源码,里面有个postProcessBeforeInstantiation方法,会返回代理对象,如果没有则不会返回代理对象。
当然还有一种思路,就是在动态添加切入点的时候把spring容器中的对象替换成自己的代理对象(没有实验过,在非单例模式的时候有问题,这里不深入研究)。
引入aop的starter:
第一步:
第二步:
jar包怎么写?只需要实现对应的切面方法就行了
通常有方法前拦截,方法后拦截,以及异常拦截。通过在这些拦截中编写自己的业务处理,可以达到特定的需求。
execution表达式
20200401:添加注入applicationContext到jar里面
https://github.com/cdInit/aopHotPlugin
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)