【AOP】基于@Aspect的AOP配置
基于spring cloud的aop配置
1,启动类MemberAppliaction增加注解
- @Import({SwaggerConfiguraion.class, WebMvcAutoConfiguration.class})
- @SpringBootApplication
- @FFanApplication
- @EnableFFanApiDoc
- @EnableAspectJAutoProxy(proxyTargetClass = true, exposeProxy=true) //启动aspect的aop注解
- @EnableAutoConfiguration
- @EnableTransactionManagement
- @EnableDiscoveryClient
- @ComponentScan(basePackages = {"cn.wanda.sail.member"})
- @MapperScan(basePackages = {"cn.wanda.sail.member.mapper"})
- @EnableFeignClients(basePackages = {"cn.wanda.sail.member.client"})
- public class MemberApplication {
2,定义切面类
- @Aspect
- @Component
- public class ProcessorAspect {
- private static final Logger log = LoggerFactory.getLogger(ProcessorAspect.class);
3,定义切入方法
- @Around("execution(public * cn.wanda.sail.member.task.support.MemberTask.process(..))") //环绕增强
- public Object execute(ProceedingJoinPoint joinPoint) throws Throwable {
- if (joinPoint.getArgs() == null || joinPoint.getArgs().length == 0) {
- return joinPoint.proceed();
- }
- TaskContext task = (TaskContext) joinPoint.getArgs()[0];
- log.info("LOG00020: {} start.....", task.getTaskId());
- long start = System.currentTimeMillis();
- Object result = null;
- try {
- result = joinPoint.proceed(); //执行目标方法
- } catch (Exception exception) {
- handleException(task.getTaskId(), exception);
- }
- log.info("LOG00040: {} end cost : {} ms", task.getTaskId(), (System.currentTimeMillis() - start));
- return result;
- }
4,常用的切入方法
(1),后置返回通知
@AfterReturning("execution(* com.sxit..*.*(..))")
(2),后置异常通知
@AfterThrowing("execution(* com.sxit..*.*(..))")
(3),后置最终通知
@After("execution(* com.sxit..*.*(..))")
(4),环绕通知
("execution(* com.sxit..*.*(..))")
(5),前置通知
@Before("execution(* com.sxit..*.*(..))")
5,定义切入点
- @Pointcut("execution(* com.sxit..*.*(..))") //针对具体要切入的方法进行说明,如果这块有说明,则切入方法@Before,@Around 都可不用再声明其具体的切入方法,直接声明pointcut声明的方法即可
- public void init(){
- }
- @Before(value="init()")
public void before(){
System.out.println("方法执行前执行.....");
}
AOP详解
AOP核心概念
1、横切关注点
对哪些方法进行拦截,拦截后怎么处理,这些关注点称之为横切关注点
2、切面(aspect)
类是对物体特征的抽象,切面就是对横切关注点的抽象
3、连接点(joinpoint)
被拦截到的点,因为Spring只支持方法类型的连接点,所以在Spring中连接点指的就是被拦截到的方法,实际上连接点还可以是字段或者构造器
4、切入点(pointcut)
对连接点进行拦截的定义
5、通知(advice)
所谓通知指的就是指拦截到连接点之后要执行的代码,通知分为前置、后置、异常、最终、环绕通知五类
6、目标对象
代理的目标对象
7、织入(weave)
将切面应用到目标对象并导致代理对象创建的过程
8、引入(introduction)
在不修改代码的前提下,引入可以在运行期为类动态地添加一些方法或字段
【AOP】基于@Aspect的AOP配置的更多相关文章
- spring 注解 之 AOP基于@Aspect的AOP配置
Spring AOP面向切面编程,可以用来配置事务.做日志.权限验证.在用户请求时做一些处理等等.用@Aspect做一个切面,就可以直接实现. 1.首先定义一个切面类,加上@Component @A ...
- spring aop 基于schema的aop
AOP的基本概念: 连接点(Jointpoint):表示需要在程序中插入横切关注点的扩展点,连接点可能是类初始化.方法执行.方法调用.字段调用或处理异常等等,Spring只支持方法执行连接点,在AOP ...
- 【Spring】基于@Aspect的AOP配置
Spring AOP面向切面编程,可以用来配置事务.做日志.权限验证.在用户请求时做一些处理等等.用@Aspect做一个切面,就可以直接实现. · 本例演示一个基于@Aspect的小demo 1. ...
- 基于@Aspect的AOP配置
1. Spring 除了支持Schema 方式配置 AOP,还支持注解方式:使用 @Aspect 来配置 2. Spring 默认不支持 @Aspect 风格的切面声明,通过如下配置开启@Aspect ...
- spring-第十七篇之spring AOP基于注解的零配置方式
1.基于注解的零配置方式 Aspect允许使用注解定义切面.切入点和增强处理,spring框架可以识别并根据这些注解来生成AOP代理.spring只是用了和AspectJ 5一样的注解,但并没有使用A ...
- 第三章 AOP 基于Schema的AOP
基于Schema定义的切面和前现两种方式定义的切面,内容上都差不多,只是表现形式不一样而已. 3.7.1一般增强的使用 a.目标类 public class Target { public void ...
- 基于aspect实现AOP——xml配置的其他操作
将上方配置中的前置通知,可换成环绕通知
- Spring AOP基于注解的“零配置”方式实现
为了在Spring中启动@AspectJ支持,需要在类加载路径下新增两个AspectJ库:aspectjweaver.jar和aspectjrt.jar.除此之外,Spring AOP还需要依赖一个a ...
- 第三章 AOP 基于@AspectJ的AOP
在前面,我们分别使用Pointcut.Advice.Advisor接口来描述切点.增强.切面.而现在我们使用@AdpectJ注解来描述. 在下面的例子中,我们是使用Spring自动扫描和管理Bean. ...
随机推荐
- HALCON 算子函数(四) File
HALCON 算子函数——Chapter 4 : File 4.1 Images 1. read_image 功能:读取有不同文件格式的图像. 2. read_sequence 功能:读取图像. 3. ...
- 【开发工具】最强Git使用总结
目录 必读材料 常用小结 Git操作流程 Git常用操作命令 - 代码提交和同步代码 Git常用操作命令 - 代码撤销和撤销同步 Git常用操作命令 - 其它常用命令 Git是分布式代码托管的标杆,这 ...
- 【转载】C# 从服务器下载文件
支持并尊重原创!原文地址:https://www.cnblogs.com/GoCircle/p/6429136.html 一.//TransmitFile实现下载 protected void But ...
- HDU ACM Fibonacci
Problem Description Fibonacci numbers are well-known as follow: Now given an integer N, please find ...
- scala中存在的问题
2017-12-27 scala学习中存在的问题: 1.表达式的概念要搞清楚 2.八种基本数据类型要搞清楚 Byte\Short\Int\Long\Char\Boolean\Double\Float都 ...
- 分布式缓存产品Redis和memcached比较区别(图)
- Mock Server实践
转载自 https://tech.meituan.com/mock-server-in-action.html 背景 在美团服务端测试中,被测服务通常依赖于一系列的外部模块,被测服务与外部模块间通过R ...
- Java生产者消费者问题
1. package interview.thread; import java.util.LinkedList; import java.util.Queue; import org.apache. ...
- 1、python与ipython的下载与安装
1.ipython的下载与安装 下载链接: wget -c https://github.com/downloads/ipython/ipython/ipython-0.13.1.tar.gz ##下 ...
- MySQL——explain性能分析的使用
用法:explain sql语句: id:查询的序号. ref:进行连接查询时,表得连接关系.可以通过上图看出. select_type:select查询的类型,主要是区别普通查询和联合查询.子查询之 ...