这篇文章主要讲解了“SpringBoot调用公共模块的自定义注解失效如何解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“SpringBoot调用公共模块的自定义注解失效如何解决”吧!

调用公共模块的自定义注解失效项目结构如下

我在 bi-common 公共模块里定义了一个自定义注解,实现AOP记录日志,bi-batch 项目已引用了 bi-common ,当在 bi-batch 使用注解的时候,没有报错,但是切面却失效。

自定义注解:

@Target(ElementType.METHOD)@Retention(RetentionPolicy.RUNTIME)public@interfaceJobLog{}

切面实现:

/***执行任务时记录日志*/@Aspect@Component@Order(1)@Slf4jpublicclassJobLogAspect{@Pointcut("@annotation(aoshu.bi.platform.common.annotation.JobLog)")publicvoidpointcut(){}@Before("pointcut()")publicvoidlogStart(JoinPointjoinPoint){log.info("开始执行"+joinPoint.getSignature().getName()+"任务,参数为:"+Arrays.toString(joinPoint.getArgs()));}@After("pointcut()")publicvoidlogEnd(JoinPointjoinPoint){log.info(""+joinPoint.getSignature().getName()+"方法运行后。。。@After");}}

注解使用:

/***这里使用了自定义注解,却失效,但是没报错*/@JobLogpublicJobcreateEsJob(StringjobName){returnjobBuilderFactory.get(jobName).start(esLogJobStep.step()).build();}解决方法

原因:

其他工程没有扫描公共模块的包,没有扫描到注解的位置。

解决方法1:

在启动类加上公共模块的包路径,注意别忘记把原项目的包路径也加上

@SpringBootApplication(scanBasePackages={"aoshu.bi.platform.batch","aoshu.bi.platform.common"})

解决方法2:

在配置类里导入该切面实现

@Import({aoshu.bi.platform.common.aspect.JobLogAspect.class})@ConfigurationpublicclassBatchConfigure{}SpringBoot注解不生效,踩坑

子模块的项目,注解都不生效,包括@RestController @EnableScheduling @Scheduled等;

解决方法

在子项目右键,clean install,会发现报错了,解决完问题以后就可以了。

感谢各位的阅读,以上就是“SpringBoot调用公共模块的自定义注解失效如何解决”的内容了,经过本文的学习后,相信大家对SpringBoot调用公共模块的自定义注解失效如何解决这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!