共计 1293 个字符,预计需要花费 4 分钟才能阅读完成。
前言
之前咱们在聊聊如何进行代码混同这篇文章提到,在 springboot 我的项目应用 allatori,有一个小坑。这个坑就是当你在 allatori.xml 配置
<input>
<jar in="${project.build.finalName}.jar" out="${project.build.finalName}.jar"/>
</input>
${project.build.finalName}会当成字符串输入,而不会解析占位符。导致在打包的会报如下错
生效起因
这个是官网原话,粗心就如果你应用了 spring-boot-starter-parent,则 maven-resources-plugin 只认 @
为啥只认 @,我贴下 spring-boot-starter-parent pom 的配置,大略大家就晓得怎么回事了
修复计划
计划一:按官网的说法,将 ${project.build.finalName}改成 @project.build.finalName@
<input>
<jar in="@project.build.finalName@.jar" out="@project.build.finalName@.jar"/>
</input>
计划二:不间接引入 spring-boot-starter-parent,而采纳
dependencyManagement,占位符依然为 ${project.build.finalName}
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>${spring-boot.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
计划三:批改 maven-resources-plugin 的 configuration
将 useDefaultDelimiters 设置 true
示例:
计划四:在 pom 的 properties 标签中,配置如下属性
<properties>
<resource.delimiter>${}</resource.delimiter>
</properties>
总结
springboot 使 maven-resources-plugin 占位符生效问题的实质起因,就是 springboot 批改了原来 maven-resources-plugin 默认的占位符。springboot 为啥这么干,他官网说了起因
他的粗心是避免配置中的任何 Spring 占位符(例如 ${foo})被构建扩大。因而举荐还是用 @
demo 链接
https://github.com/lyb-geek/springboot-learning/tree/master/springboot-proguard