minify-maven-plugin (com.samaxes.maven v1.7.6) 没有用原始文件替换缩小的文件

minify-maven-plugin (com.samaxes.maven v1.7.6) is not replacing the minified files with the original files

我想缩小 maven 项目中的 JS 和 CSS 文件。我使用过 minify-maven-plugin (com.samaxes.maven v1.7.6)。根据文档 (https://samaxes.github.io/minify-maven-plugin/minify-mojo.html),我已将 <nosuffix> 和 <skipMerge> 设置为 true 因为我想维护文件结构并用原始文件替换缩小文件。我还设置了 <phase>packagephase>。 生成并部署 WAR 文件后,JS 和 CSS 文件没有缩小,它们与之前保持不变。 我还参考了一些 Whosebug 答案并根据 提供的建议设置了 <warSourceExcludes> 选项 使用 <warSourceExcludes> 选项后,当我在服务器上部署 WAR 文件时,JS 和 CSS 文件不可用并且应用程序显示 404同样的错误。请参考我的pom.xml配置:

        <plugin>
            <artifactId>maven-war-plugin</artifactId>
            <version>3.2.1</version>
            <configuration>
                <warSourceDirectory>WebContent</warSourceDirectory>
                <warSourceExcludes>**/*.css,**/*.js</warSourceExcludes>
            </configuration>
        </plugin>
        <plugin>
            <groupId>com.samaxes.maven</groupId>
            <artifactId>minify-maven-plugin</artifactId>
            <version>1.7.6</version>
            <executions>
                <execution>
                    <id>default-minify</id>
                    <phase>package</phase>
                    <configuration>
                        <charset>UTF-8</charset>
                        <webappSourceDir>${project.basedir}/WebContent</webappSourceDir>

                        <cssSourceDir>./</cssSourceDir>
                        <cssSourceIncludes>
                            <cssSourceInclude>**/*.css</cssSourceInclude>
                        </cssSourceIncludes>
                        <cssSourceExcludes>
                            <cssSourceExclude>**/*.min.css</cssSourceExclude>
                        </cssSourceExcludes>

                        <jsSourceDir>./</jsSourceDir>
                        <jsSourceIncludes>
                            <jsSourceInclude>**/*.js</jsSourceInclude>
                        </jsSourceIncludes>
                        <jsSourceExcludes>
                            <jsSourceExclude>**/*.min.js</jsSourceExclude>
                        </jsSourceExcludes>

                        <jsEngine>CLOSURE</jsEngine>
                        <nosuffix>true</nosuffix>
                        <skipMerge>true</skipMerge>
                    </configuration>
                    <goals>
                        <goal>minify</goal>
                    </goals>
                </execution>
            </executions>
        </plugin>

请提出合适的解决方案。提前致谢!

@Kristof Neirynck 对问题 How to get maven to build a war with minified files using yuicompressor-maven-plugin 给出的答案适用于所提到的问题。 我将 <phase> 属性 更改为 prepare-package 并添加了

<webappTargetDir>${project.build.directory}/minify</webappTargetDir> 

minify-maven-plugin 之后 <webappSourceDir> 和 maven-war -plugin 我设置如下配置:

        <plugin>
            <artifactId>maven-war-plugin</artifactId>
            <version>3.2.1</version>
            <configuration>
                <warSourceDirectory>WebContent</warSourceDirectory>
                <webResources>
                    <resource>
                        <directory>${project.build.directory}/minify</directory>
                    </resource>
                </webResources>
            </configuration>
        </plugin>

使用此配置后,当我在 Tomcat 中部署 WAR 文件时,原始文件将替换为缩小后的文件。