Spring Boot多模块项目中程序可运行但mvn install 时找不到类

问题描述

A模块引用了B模块

java 复制代码
@ComponentScan(
    basePackages = {"com.moduleA", "com.moduleB", com.moduleB.util"},
    excludeFilters = {
        @ComponentScan.Filter(type = FilterType.CUSTOM, classes = {A.class})
    }
)
java 复制代码
mvn install 
[ERROR] A.class不存在

常见原因分析

模块依赖未正确定义

父模块的pom.xml未正确声明子模块,或子模块间未通过<dependencies>正确引用。

构建顺序问题

Maven/Gradle未按依赖顺序编译模块,导致被依赖模块未优先编译。

类路径扫描失效

Spring Boot的组件扫描未包含依赖模块的包路径,导致@Component等注解未被识别。

编译时类不可用

@ComponentScan 的 excludeFilters 使用 FilterType.ASSIGNABLE_TYPE 直接引用类,但这些类在编译时可能不可用(即使已声明依赖),导致编译失败

解决方案

解决方案

  1. 创建自定义过滤器 ClassNameExcludeFilter:通过字符串类名匹配需要排除的类,避免编译时类引用。
  1. 修改 Application上面的注解:使用 FilterType.CUSTOM 和自定义过滤器。
java 复制代码
public class ClassNameExcludeFilter implements TypeFilter {

    private static final Set<String> EXCLUDED_CLASS_NAMES = new HashSet<>(Arrays.asList(
            "*"
    ));

    @Override
    public boolean match(MetadataReader metadataReader, MetadataReaderFactory metadataReaderFactory) {
        String className = metadataReader.getClassMetadata().getClassName();
        return EXCLUDED_CLASS_NAMES.contains(className);
    }
}

检查打包结果

确认依赖模块生成的jar包含编译后的类和资源文件。可通过解压jar或检查target/classes目录验证。

高级调试技巧

  • 使用mvn dependency:tree分析依赖树,排除冲突或缺失。
  • 在IDE中检查模块的类路径是否包含依赖模块的输出目录(如target/classes)。
  • 对于Gradle,启用--debug日志查看详细构建过程。
相关推荐
逍遥德3 天前
Maven教程.02-基础-pom.xml 使用标签大全
java·后端·maven·软件构建
逍遥德3 天前
Maven教程.01- settings.xml 文件<profile>使用详解
xml·java·maven
逍遥德3 天前
Maven教程.04-如何阅读Maven项目
java·maven
逍遥德3 天前
Maven教程.03-如何阅读pom.xml文件
xml·java·后端·maven
塔中妖3 天前
Windows 安装 Maven 详细教程(含镜像与本地仓库配置)
java·windows·maven
成为你的宁宁3 天前
Jenkins 自动化部署前后端分离若依项目全攻略:涵盖环境配置、Maven/Node.js 工具安装、GitLab 项目协同,及前后端构建、服务器推送与代码更新验证全步骤
node.js·自动化·gitlab·jenkins·maven
玄〤4 天前
个人博客网站搭建day5--MyBatis-Plus核心配置与自动填充机制详解(漫画解析)
java·后端·spring·mybatis·springboot·mybatis plus
没有bug.的程序员4 天前
依赖治理之巅:Maven 与 Gradle 依赖树分析内核、冲突判定博弈与工程自愈实战指南
java·gradle·maven·依赖治理·冲突判定·依赖树
三无少女指南4 天前
Spring Boot项目中Maven编译参数source、target与release的区别及配置实践
java·spring boot·maven