解决Aspcet切面类无法启动/启动无效

在使用SpringBoot+MyBatis框架时,创建的AOP切面ControllerAspect无法正常工作,无法监听到目标控制器。通过调整Pointcut的execution路径配置,并在启动类中添加特定注解后,问题得到解决。起初怀疑是Pointcut表达式、SpringBoot或AspectJ版本不匹配,但最终发现是缺少了启动类的特定配置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

背景:

从公司的项目中抽出了一个springboot + mybaties框架,学着已有的框架写了一个AOP切面类,ControllerAspect,用来输出进入指定controller包下所有控制器的请求信息,并将其打印到日志中。但程序运行后,发现这个切面没法织入,没法监听到目标控制器。

 

结构:

 

代码:

ControllerAspect

/**
 * 实现Web层的日志切面
 * @author qzj
 * @version v0.0.1-SNAPSHOT
 */
@Aspect
@Component
public class ControllerAspect {

    private Logger logger =  LoggerFactory.getLogger(this.getClass());

    /**
     * 定义一个切入点.
     * 解释下:
     *
     * ~ 第一个 * 代表任意修饰符及任意返回值.
     * ~ 第二个 * 任意包名
     * ~ 第三个 * 代表任意方法.
     * ~ 第四个 * 定义在web包或者子包
     * ~ 第五个 * 任意方法
     * ~ .. 匹配任意数量的参数.
     */
    @Pointcut("execution(* com.zjqiu.pwdmng.controller.system.*.*(.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值