基于spring cloud的aop配置

1,启动类MemberAppliaction增加注解

  1. @Import({SwaggerConfiguraion.class, WebMvcAutoConfiguration.class})
  2. @SpringBootApplication
  3. @FFanApplication
  4. @EnableFFanApiDoc
  5. @EnableAspectJAutoProxy(proxyTargetClass = true, exposeProxy=true) //启动aspect的aop注解
  6. @EnableAutoConfiguration
  7. @EnableTransactionManagement
  8. @EnableDiscoveryClient
  9. @ComponentScan(basePackages = {"cn.wanda.sail.member"})
  10. @MapperScan(basePackages = {"cn.wanda.sail.member.mapper"})
  11. @EnableFeignClients(basePackages = {"cn.wanda.sail.member.client"})
  12. public class MemberApplication {

2,定义切面类

  1. @Aspect
  2. @Component
  3. public class ProcessorAspect {
  4.  
  5. private static final Logger log = LoggerFactory.getLogger(ProcessorAspect.class);

3,定义切入方法

  1. @Around("execution(public * cn.wanda.sail.member.task.support.MemberTask.process(..))") //环绕增强
  2. public Object execute(ProceedingJoinPoint joinPoint) throws Throwable {
  3. if (joinPoint.getArgs() == null || joinPoint.getArgs().length == 0) {
  4. return joinPoint.proceed();
  5. }
  6. TaskContext task = (TaskContext) joinPoint.getArgs()[0];
  7. log.info("LOG00020: {} start.....", task.getTaskId());
  8. long start = System.currentTimeMillis();
  9. Object result = null;
  10. try {
  11. result = joinPoint.proceed(); //执行目标方法
  12. } catch (Exception exception) {
  13. handleException(task.getTaskId(), exception);
  14. }
  15. log.info("LOG00040: {} end cost : {} ms", task.getTaskId(), (System.currentTimeMillis() - start));
  16.  
  17. return result;
  18. }

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,定义切入点

  1. @Pointcut("execution(* com.sxit..*.*(..))") //针对具体要切入的方法进行说明,如果这块有说明,则切入方法@Before,@Around 都可不用再声明其具体的切入方法,直接声明pointcut声明的方法即可
  2. public void init(){
  3. }
  4.  
  5. @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配置的更多相关文章

  1. spring 注解 之 AOP基于@Aspect的AOP配置

    Spring AOP面向切面编程,可以用来配置事务.做日志.权限验证.在用户请求时做一些处理等等.用@Aspect做一个切面,就可以直接实现. 1.首先定义一个切面类,加上@Component  @A ...

  2. spring aop 基于schema的aop

    AOP的基本概念: 连接点(Jointpoint):表示需要在程序中插入横切关注点的扩展点,连接点可能是类初始化.方法执行.方法调用.字段调用或处理异常等等,Spring只支持方法执行连接点,在AOP ...

  3. 【Spring】基于@Aspect的AOP配置

    Spring AOP面向切面编程,可以用来配置事务.做日志.权限验证.在用户请求时做一些处理等等.用@Aspect做一个切面,就可以直接实现. ·   本例演示一个基于@Aspect的小demo 1. ...

  4. 基于@Aspect的AOP配置

    1. Spring 除了支持Schema 方式配置 AOP,还支持注解方式:使用 @Aspect 来配置 2. Spring 默认不支持 @Aspect 风格的切面声明,通过如下配置开启@Aspect ...

  5. spring-第十七篇之spring AOP基于注解的零配置方式

    1.基于注解的零配置方式 Aspect允许使用注解定义切面.切入点和增强处理,spring框架可以识别并根据这些注解来生成AOP代理.spring只是用了和AspectJ 5一样的注解,但并没有使用A ...

  6. 第三章 AOP 基于Schema的AOP

    基于Schema定义的切面和前现两种方式定义的切面,内容上都差不多,只是表现形式不一样而已. 3.7.1一般增强的使用 a.目标类 public class Target { public void ...

  7. 基于aspect实现AOP——xml配置的其他操作

    将上方配置中的前置通知,可换成环绕通知

  8. Spring AOP基于注解的“零配置”方式实现

    为了在Spring中启动@AspectJ支持,需要在类加载路径下新增两个AspectJ库:aspectjweaver.jar和aspectjrt.jar.除此之外,Spring AOP还需要依赖一个a ...

  9. 第三章 AOP 基于@AspectJ的AOP

    在前面,我们分别使用Pointcut.Advice.Advisor接口来描述切点.增强.切面.而现在我们使用@AdpectJ注解来描述. 在下面的例子中,我们是使用Spring自动扫描和管理Bean. ...

随机推荐

  1. HALCON 算子函数(四) File

    HALCON 算子函数——Chapter 4 : File 4.1 Images 1. read_image 功能:读取有不同文件格式的图像. 2. read_sequence 功能:读取图像. 3. ...

  2. 【开发工具】最强Git使用总结

    目录 必读材料 常用小结 Git操作流程 Git常用操作命令 - 代码提交和同步代码 Git常用操作命令 - 代码撤销和撤销同步 Git常用操作命令 - 其它常用命令 Git是分布式代码托管的标杆,这 ...

  3. 【转载】C# 从服务器下载文件

    支持并尊重原创!原文地址:https://www.cnblogs.com/GoCircle/p/6429136.html 一.//TransmitFile实现下载 protected void But ...

  4. HDU ACM Fibonacci

    Problem Description Fibonacci numbers are well-known as follow: Now given an integer N, please find ...

  5. scala中存在的问题

    2017-12-27 scala学习中存在的问题: 1.表达式的概念要搞清楚 2.八种基本数据类型要搞清楚 Byte\Short\Int\Long\Char\Boolean\Double\Float都 ...

  6. 分布式缓存产品Redis和memcached比较区别(图)

  7. Mock Server实践

    转载自 https://tech.meituan.com/mock-server-in-action.html 背景 在美团服务端测试中,被测服务通常依赖于一系列的外部模块,被测服务与外部模块间通过R ...

  8. Java生产者消费者问题

    1. package interview.thread; import java.util.LinkedList; import java.util.Queue; import org.apache. ...

  9. 1、python与ipython的下载与安装

    1.ipython的下载与安装 下载链接: wget -c https://github.com/downloads/ipython/ipython/ipython-0.13.1.tar.gz ##下 ...

  10. MySQL——explain性能分析的使用

    用法:explain sql语句: id:查询的序号. ref:进行连接查询时,表得连接关系.可以通过上图看出. select_type:select查询的类型,主要是区别普通查询和联合查询.子查询之 ...