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,会发现报错了,解决完问题以后就可以了。

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

相关文章

  • Java连接六类数据库技巧全攻略

    Java连接六类数据库技巧全攻略

    本文主要为大家介绍了Java与Oracle、DB2、Sql Server、Sybase、MySQL、PostgreSQL等数据库连接的方法。
    2015-09-09
  • java垃圾回收之实现串行GC算法

    java垃圾回收之实现串行GC算法

    学习了GC算法的相关概念之后, 我们将介绍在JVM中这些算法的具体实现。首先要记住的是, 大多数JVM都需要使用两种不同的GC算法 —— 一种用来清理年轻代, 另一种用来清理老年代
    2022-01-01
  • java如何解析/读取xml文件

    java如何解析/读取xml文件

    这篇文章主要为大家详细介绍了java如何解析/读取xml文件的方法,感兴趣的小伙伴们可以参考一下
    2016-03-03
  • Java设计模式七大原则之里氏替换原则详解

    Java设计模式七大原则之里氏替换原则详解

    在面向对象的程序设计中,里氏替换原则(Liskov Substitution principle)是对子类型的特别定义。本文将为大家详细介绍Java设计模式七大原则之一的里氏替换原则,需要的可以参考一下
    2022-02-02
  • 微信小程序与Java后端接口交互

    微信小程序与Java后端接口交互

    本文主要介绍了微信小程序与Java后端接口交互,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-07-07
  • 使用JSONObject生成和解析json的方法

    使用JSONObject生成和解析json的方法

    下面小编就为大家带来一篇使用JSONObject生成和解析json的方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-06-06
  • Java小程序计算圆周率代码

    Java小程序计算圆周率代码

    这篇文章主要介绍了Java小程序计算圆周率代码,有两种实现方法,喜欢的朋友可以参考下。
    2017-09-09
  • win10操作系统下重启电脑java环境变量失效

    win10操作系统下重启电脑java环境变量失效

    这篇文章主要介绍了win10操作系统下重启电脑java环境变量失效,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09
  • 利用线程实现动态显示系统时间

    利用线程实现动态显示系统时间

    编写Applet小程序,通过在HTML文档中接收参数,显示当前的系统时间,需要的朋友可以参考下
    2015-10-10
  • 详解分别用Kotlin和java写RecyclerView的示例

    详解分别用Kotlin和java写RecyclerView的示例

    本篇文章主要介绍了详解分别用Kotlin和java写RecyclerView的示例,详解分别用Kotlin和java写RecyclerView的示例
    2017-12-12

最新评论