非maven项目快速转换为maven项目

非maven项目快速转换为maven项目

背景

公司有个很旧的项目,无法通过提交gitlab来实现自动构建docker镜像(当然肯定可以通过其他的方式来构建镜像(这里可能没有研究所以不太清楚),但是我当时的想法就是把项目转换为maven的,然后通过配置plugin来实现)。

问题

因为旧的项目是spring的项目可想而知是很多的jar包,并且还有一些奇奇怪怪的jar包(可能是第三方的,在中央库根本就找不到)。这是很头疼的,尝试去找了每用一个jarGAV,因为太多了就放弃了。然后就想是否能直接通过配置方式来解决这个问题,快速把所有jar引入到项目中,并且可以使他在maven编译的时候也可以正常编译(虽然在idea中可以运行是因为我们配置了libraries所有才能正常运行)。

解决方式

方法只适用与jdk1.8及以下,因为1.8以上他取消了rt.jar这个基础包。

<plugin>
    <!--使用maven-compiler-plugin来解决编译时无法找到第三方依赖的问题-->
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-compiler-plugin</artifactId>
    <version>3.1</version>
    <configuration>
        <source>1.8</source>
        <target>1.8</target>
        <!-- 指定源代码的字符编码为UTF-8。-->
        <encoding>UTF-8</encoding>
        <!-- 用于指定传递给Java编译器的参数。-->
        <compilerArgs>
            <!--一般不开调试的时候需要用到 这三个一般不开启 但是调试的时候可以通到-->
            <!--启用详细输出,显示编译过程的详细信息。-->
            <!--<arg>-verbose</arg>-->
            <!--启用unchecked警告,用于检测未经检查的操作。-->
            <!--<arg>-Xlint:unchecked</arg>-->
            <!--启用已过时元素使用警告,用于检测已经不推荐使用的API。-->
            <!--<arg>-Xlint:deprecation</arg>-->
            <!--bootclasspath 引导类路径。引导类路径是Java编译器在编译时使用的类路径,其中包含了Java标准库的核心类 其实可以不指定。因为jdk11我测试的时候没找到rt.jar 所以说只支持jdk1.8及一下 这里如果这个的可以补充-->
            <arg>-bootclasspath</arg>
            <arg>${env.JAVA_HOME}/jre/lib/rt.jar</arg>
            <!--重点!
				extdirs 扩展目录允许你添加额外的类库目录,这里包括了Web应用程序的lib目录和Java运行时库的ext目录。
				我们把自己的第三方jar包通过扩展类的形式让我们的编译器可以识别到。从而使得maven能够编译成功。
			-->
            <arg>-extdirs</arg>
            <arg>
                ${project.basedir}/src/main/webapp/WEB-INF/lib${path.separator}${env.JAVA_HOME}/jre/lib/ext
            </arg>
        </compilerArgs>
    </configuration>
</plugin>
<plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-war-plugin</artifactId>
    <version>3.2.2</version>
    <configuration>
       	<!--用于补充Web应用程序的资源文件。-->
        <webResources>
            <webResource>
                <!--用于在部署后可以让我们的tomcat识别到具有必要的第三方依赖-->
                <directory>${pom.basedir}/src/main/webapp/WEB-INF/lib/</directory>
                <!--将资源复制到指定目录-->
                <targetPath>WEB-INF/lib/</targetPath>
              	<!--包含那些文件-->
                <includes>
                    <include>**/*.jar</include>
                </includes>
            </webResource>
        </webResources>
    </configuration>
</plugin>

总结

maven-compiler-plugin:解决在编译过程中识别不到第三方依赖的问题

maven-war-plugin:解决在部署后可以让第三方包被tomcat识别

使用这两个插件让我们可以无需一个一个的添加denpendency,之后的有再补充的jar包,可以通过denpendency交给maven来管理。

注意

idea工具中你可能还需要将webapp/WEB-INF/lib/添加到libraries中,因为idea默认不是使用maven来编译程序的。

  • 25
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

假女吖☌

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值