场景是这样:依赖和代码逻辑分开打包,这样修改代码后上传服务器更新轻松,传送时间更短,配置改动也不用再重新打包了。按照其他博主的做法,一般来说,是没什么大问题的,问题就在于我多了一个自己的本地common包,然后在打包项目的时候,common包结构被损坏了,导致在服务器运行失败,显示无法引用common包中的类,这个问题从排查到解决真的是废了long long long … time 服
我的common包位置
参照其他博主文章后根据我的实际情况修改后的pom.xml
<dependency>
<groupId>org.jeecgframework.boot</groupId>
<artifactId>jeecg-boot-base-common</artifactId>
<version>2.1.3</version>
<scope>system</scope>
<systemPath>${pom.basedir}/src/main/resources/lib/jeecg-boot-base-common-2.1.3.jar</systemPath>
</dependency>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<includeSystemScope>true</includeSystemScope>
<skip>true</skip>
</configuration>
</plugin>
<!--maven-compiler-plugin 指定项目源码的jdk版本,编译后的jdk版本,以及编码-->
<plugin>
<artifactId>maven-compiler-plugin</artifactId>
<version>2.3.2</version>
<configuration>
<source>1.8</source>
<target>1.8</target>
</configuration>
</plugin>
<!--MANIFEST.MF 中 Class-Path 加入资源文件目录 -->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-dependency-plugin</artifactId>
<executions>
<execution>
<id>copy-dependencies</id>
<phase>prepare-package</phase>
<goals>
<goal>copy-dependencies</goal>
</goals>
<configuration>
<outputDirectory>${project.build.directory}/lib</outputDirectory>
<overWriteReleases>false</overWriteReleases>
<overWriteSnapshots>false</overWriteSnapshots>
<overWriteIfNewer>true</overWriteIfNewer>
</configuration>
</execution>
</executions>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-jar-plugin</artifactId>
<version>2.6</version>
<configuration>
<archive>
<manifest>
<!--指定入口启动类 -->
<mainClass>com.*.*.*Application</mainClass>
<addClasspath>true</addClasspath>
<!--指定项目依赖读取路径,绝对路径或相对路径都可 -->
<!-- <classpathPrefix>/usr/maven/libs/</classpathPrefix> -->
<classpathPrefix>lib/</classpathPrefix>
<!--jar包不包含唯一版本标识 -->
<useUniqueVersions>false</useUniqueVersions>
</manifest>
<manifestEntries>
<!--MANIFEST.MF 中 Class-Path 加入资源文件目录 -->
<Class-Path>./</Class-Path>
<!--要是打入第三方依赖的包的时候,这个重点!!!否则可以忽视,在META-INF/MANIFEST.MF的Class-Path添加加载这3个jar包 -->
<Class-Path>lib/jeecg-boot-base-common-2.1.3.jar</Class-Path>
</manifestEntries>
</archive>
<!--不将以下文件打入jar包中-->
<excludes>
<exclude>*.properties</exclude>
<exclude>*.yml</exclude>
<exclude>*.xml</exclude>
<exclude>lib/*.jar</exclude>
</excludes>
</configuration>
</plugin>
<!--maven-resources-plugin负责处理项目资源文件并拷贝到输出目录-->
<plugin>
<artifactId>maven-resources-plugin</artifactId>
<executions>
<execution>
<id>copy-resources</id>
<phase>validate</phase>
<goals>
<goal>copy-resources</goal>
</goals>
<configuration>
<outputDirectory>${project.build.directory}</outputDirectory>
<resources>
<resource>
<directory>src/main/resources</directory>
<filtering>true</filtering>
</resource>
</resources>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
<resources>
<resource>
<directory>src/main/java</directory>
<includes>
<include>**/*Mapper.xml</include>
</includes>
</resource>
<!--打包的时候加入这个-->
<resource>
<directory>src/main/resources</directory>
<includes>
<include>**/*.*</include>
</includes>
<filtering>true</filtering>
</resource>
</resources>
</build>
打包后直接运行jar 还是不行的,因为commom包还是会在打包过程中被损坏,然后需要手动更换服务器上lib文件夹下面的common包,如果有出错的,要看看是不是项目打包的时候把common包,配置文件什么的给打进去了,导致他还是调用的项目包里面已被损坏的common包,我打完包后 解压是没有配置文件的,lib也不包含任何依赖包
至此 运行成功,鸣谢周某