在带团队的时候,难免会在对接第三方服务的时候,第三方提供了一个SDK或者一个jar包,我们有两种处理方案,
第一种:上传到自己公司的Nexus私服,添加私服的坐标依赖
第二种:放在项目里面,在pom中添加本地依赖
我们是第二种,原因是:这个第三方jar一直会变,而且只有目前这一个项目在使用,所以增量添加是没什么问题的,但是这个时候在本地开发都很正常,但是放在线上就报错有个类找不到,这个类恰好是本地依赖的jar中的某个类,于是开发就找到我了,我们的对话是这样的
开发:bing哥,我本地是有这个jar的,我在IDE中直接定位也能找到这个本地依赖的jar位置(也就是ctrl+鼠标左键),但是打包放在线上,一请求接口就报错,报错是这样的,我本地依赖是这样的
然后给我看了他的报错和依赖
<dependency> <groupId>com.abc</groupId> <artifactId>openbank-sdk-java</artifactId> <version>1.0.0</version> <scope>system</scope> <systemPath>${project.basedir}/lib/openbank-sdk-java.jar</systemPath> </dependency>
我过去看了一下,依赖没问题,而且确实可以定位,错误也很准确,就是这个类没找到
我:你本地打包一下
打包ing,使用的是mvn clean install -DskipTests命令,打包命令也没错,然后打包出来了,我用她电脑自带的解压工具,把jar包打开,找到了jar所在位置,查了一下并没有上面依赖artifactId的jar包,所以问题定位到了
依赖确实没问题,但是它有个变量${project.basedir},所以你直接定位,IDE 会自动帮你识别,你直接使用ctrl+鼠标左键,是可以直接定位到这个jar,但是对于maven来说, 他在打包的时候,有些参数会有些许变化,所以要让maven在打包的时候识别到这个依赖的 scope等信息,允许识别外部jar包即可
我:你在maven的plugin插件那里加上这两标签,应该就可以了
<plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> <!--加上configuration中的两个标签即可--> <configuration> <!--代表maven打包时会将外部引入的jar包--> <includeSystemScope>true</includeSystemScope> <executable>false</executable> </configuration> </plugin> </plugins>
开发:我加上了,我在打包看看哈~
a minute later...
开发:bing哥,可以了,新打的jar已经把刚才没有识别的本地jar包放进去了,而且用jenkins构建也不报错了
本地依赖的jar用这个方式就解决了,不知道有没有帮助到现在正在看这个问题的你呢^_^!