Spring Aop @target的坑

文章讨论了在SpringBoot中使用@Pointcut注解时遇到的BeanCreationException,该异常通常由于尝试为final类或不可见类生成CGLIB子类导致。建议将@Pointcut改为@within或@annotation来避免为所有bean生成代理类,从而防止报错。
摘要由CSDN通过智能技术生成

1、SpringBoot使用@Pointcut(“@target(xxxxx)”)报错

org.springframework.beans.factory.BeanCreationException: Error creating bean wi
th name 'meterRegistryPostProcessor' defined in class path resource [org/springf
ramework/boot/actuate/autoconfigure/metrics/MetricsAutoConfiguration.class]: Ini
tialization of bean failed; nested exception is org.springframework.aop.framewor
k.AopConfigException: Could not generate CGLIB subclass of class org.springframe
work.boot.actuate.autoconfigure.metrics.MeterRegistryPostProcessor: Common cause
s of this problem include using a final class or a non-visible class; nested exc
eption is org.springframework.cglib.core.CodeGenerationException: java.lang.Ille
galAccessError-->class org.springframework.boot.actuate.autoconfigure.metrics.Me
terRegistryPostProcessor$$EnhancerBySpringCGLIB$$3a6cf68c cannot access its supe
rclass org.springframework.boot.actuate.autoconfigure.metrics.MeterRegistryPostP
rocessor
java.lang.IllegalAccessError: class org.springframework.boot.actuate.autoconfigu
re.metrics.MeterRegistryPostProcessor$$EnhancerBySpringCGLIB$$3a6cf68c cannot ac
cess its superclass org.springframework.boot.actuate.autoconfigure.metrics.Meter
RegistryPostProcessor

2、建议修改成

@Pointcut(“@within(xxxxx)”) 代理类
@Pointcut(“@annotation(xxxxx)”) 代理方法

3、原因

@target匹配的是运行时的类型,会给所有bean生成代理类,生成失败就会报错

@Around是Spring AOP中的一个注解,用于定义环绕通知。环绕通知是在被通知的方法执行前后都会执行的通知。它可以控制被通知方法的执行,并可以在执行前后进行一些额外的处理逻辑。[1] 在使用@Around注解时,需要编写一个环绕通知方法,方法需要带有ProceedingJoinPoint类型的参数。ProceedingJoinPoint参数可以让我们在通知方法中控制被通知方法的执行,例如在方法执行前后打印日志、计算执行耗时等操作。通过调用ProceedingJoinPoint的proceed()方法,可以继续执行被通知方法,也可以在此中断方法的执行。 例如,下面是一个使用@Around注解的示例: ```java @Aspect @Component public class PerformanceAspect { @Around("execution(* com.example.MyService.myMethod(..))") public Object measureExecutionTime(ProceedingJoinPoint joinPoint) throws Throwable { long startTime = System.currentTimeMillis(); Object result = joinPoint.proceed(); long endTime = System.currentTimeMillis(); long executionTime = endTime - startTime; System.out.println("Execution Time: " + executionTime + "ms"); return result; } } ``` 以上示例中,使用@Around注解定义了一个名为measureExecutionTime的环绕通知方法。该方法接收一个ProceedingJoinPoint参数,通过调用proceed()方法执行被通知方法,并计算方法的执行耗时。最后,打印出执行时间。 请注意,上述示例中的切点表达式"execution(* com.example.MyService.myMethod(..))"需要根据实际情况进行修改,以匹配需要添加执行耗时的方法。 通过使用@Around注解,我们可以方便地在Spring AOP中实现对方法的执行耗时的监控和记录。<span class="em">1</span> #### 引用[.reference_title] - *1* [【注解】Spring AOP 面向切面编程之@Around的详细用法](https://blog.csdn.net/weixin_44299027/article/details/124489435)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值