SpringBoot调用公共模块的自定义注解失效的解决

 更新时间:2022年02月18日 15:28:01   作者:章全蛋  
这篇文章主要介绍了SpringBoot调用公共模块的自定义注解失效的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

调用公共模块的自定义注解失效

项目结构如下

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

自定义注解:

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

切面实现:

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

注解使用:

	/**
	 *  这里使用了自定义注解,却失效,但是没报错
	 */
    @JobLog
    public Job createEsJob(String jobName) {
        return jobBuilderFactory.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
})
@Configuration
public class BatchConfigure {
}

SpringBoot注解不生效,踩坑

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

解决方法

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

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • MyBatis常用标签大全

    MyBatis常用标签大全

    这篇文章主要介绍了MyBatis常用标签大全的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-12-12
  • Spring Dao层@Repository与@Mapper的使用

    Spring Dao层@Repository与@Mapper的使用

    这篇文章主要介绍了Spring Dao层@Repository与@Mapper的使用方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-02-02
  • Java volatile的几种使用场景分析

    Java volatile的几种使用场景分析

    volatile 是一种轻量级的同步机制,它能保证共享变量的可见性,同时禁止重排序保证了操作的有序性,但是它无法保证原子性,本文给大家总结了Java olatile的使用场景有哪些,并通过代码示例讲解的非常详细,需要的朋友可以参考下
    2024-03-03
  • SpringBoot三种打包方法举例详解

    SpringBoot三种打包方法举例详解

    这篇文章主要给大家介绍了关于SpringBoot三种打包方法的相关资料,Spring Boot是一个开发框架,目的是简化Spring应用的初始搭建过程和开发过程,文中提供了3种打包方法,需要的朋友可以参考下
    2023-12-12
  • SpringBoot使用redis实现session共享功能

    SpringBoot使用redis实现session共享功能

    这篇文章主要介绍了pringboot项目使用redis实现session共享,文中通过代码示例讲解的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下
    2024-05-05
  • Java如何随机生成图片验证码

    Java如何随机生成图片验证码

    这篇文章主要为大家详细介绍了Java如何随机生成图片验证码,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-12-12
  • Java服务限流算法的6种实现

    Java服务限流算法的6种实现

    服务限流是指通过控制请求的速率或次数来达到保护服务的目的,本文主要介绍了Java服务限流算法的6种实现,具有一定的参考价值,感兴趣的可以了解一下
    2023-05-05
  • SpringCloud Zuul服务功能与使用方法解析

    SpringCloud Zuul服务功能与使用方法解析

    这篇文章主要介绍了SpringCloud Zuul服务功能与使用方法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-05-05
  • Spring boot 集成 Druid 数据源过程详解

    Spring boot 集成 Druid 数据源过程详解

    这篇文章主要介绍了Spring boot 集成 Druid 数据源过程详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-08-08
  • java实现服务器巡查的代码

    java实现服务器巡查的代码

    接到上级领导任务,需要实现一个这样的需求,一大批服务器,需要检查服务器能否ping通,ssh密码是否正常,以及检查服务器的cpu,内存,硬盘占用情况,下面通过java代码实现服务器巡查功能,需要的朋友一起看看吧
    2021-12-12

最新评论