0. 问题描述

在进行项目打包的时候发现执行maven install会出现报错:找不到符号

[ERROR] /Library/project/work/fantu_java/digitalenterprise_business/bladex-biz/blade-service-api/blade-fleet-basic-api/src/main/java/org/springblade/fleetbasic/feign/IBasicGoldMedalDriverAreaFeign.java:[18,38] 找不到符号
  符号:   变量 APPLICATION_FLEET_BASIC_PROVIDER_NAME
  位置: 接口 org.springblade.common.constant.LauncherConstant
[ERROR] /Library/project/work/fantu_java/digitalenterprise_business/bladex-biz/blade-service-api/blade-fleet-basic-api/src/main/java/org/springblade/fleetbasic/feign/IBasicFileFeign.java:[20,38] 找不到符号
  符号:   变量 APPLICATION_FLEET_BASIC_PROVIDER_NAME
  位置: 接口 org.springblade.common.constant.LauncherConstant

1. 解决思路

首先我们要明确出现这个问题可能的原因:

  • 项目编码格式不统一
  • 项目编码使用的JDK版本不一致
  • pom依赖未添加或者读取不到,一般是版本号不一致的问题
  • 开发工具bug,一般靠重启或者升级版本解决

我首先排除掉的原因是pom依赖问题,因为项目中已经添加了对应依赖了,且在idea中运行是正常的,就是maven install的会报错

其次检查了下项目的jdk版本都是1.8,所以第二个原因也排除

于是我又尝试了在pom中指定编码格式,但是重新install后依然报错。

<plugin>
     <groupId>org.apache.maven.plugins</groupId>
     <artifactId>maven-compiler-plugin</artifactId>
     <version>3.3</version>
     <configuration>
       <source>1.8</source>
       <target>1.8</target>
       <encoding>UTF-8</encoding>
     </configuration>
  </plugin>

到这里发现都走不通,于是怀疑是本机环境的问题,于是重启后再次install。发现还是报错。尝试让其他同事maven install,这个时候就出现了比较神奇的现象,有的同事可以正常install,而有的同事和我报一样的错。

大家看到这里,能想到是什么原因导致的吗?

2. 最终解决方案

其实我们有时候解决问题要看到本质,坚定自己掌握的知识。就像这个问题,我所了解到的导致这个问题的原因就是上述所说的四个,去查询了相关资料,也就只有这四个。

而且有的同事可以打包,有的不行,就说明不是环境的问题。于是我重新检查了pom的依赖关系,重点关注了LauncherConstant接口类所在的jar包,这个包是我们自定义的commons模块中的。当我仔细检查了这个commons的pom之后就发现了问题所在

commons中的打包方式,不知道被哪位同事给设置成了pom,也就导致commons一直没有被打包成jar,从而引用不了。而有的同事可以正常打包,是因为并没有重新install commons模块,本地maven仓库中还是有commons模块的jar包。

解决办法也很简单,就是把package改为jar,或者直接删除掉这个标签,因为pom中不填写打包方式默认就是jar

<packaging>jar</packaging>

这里也提醒我们,项目开发中注意细节,一些小的知识点掌握的不够牢靠的话,很可能导致很难排查的问题。

原文地址:https://wu55555.blog.csdn.net/article/details/124076979