设置 javascript 文件的版本。 Java EE + Tomcat

Set version of javascript file. Java EE + Tomcat

通过向 javascript 和 css 添加更新,我想避免强制用户按 Ctrl+F5 来刷新缓存的 js 和 css 文件。

禁用缓存也不是一个选择。

为此,我想将版本添加到 js 和 css 这样的链接

< link href="~/CSS/file.css?MY_VERSION" rel="stylesheet" />

理想情况下,版本必须类似于构建日期和时间的构建编号。
但是我怎样才能自动设置呢?

我根本不想在每次更新后手动更新此值 jsp 个文件。 所以问题是

是的,我们做了类似的事情(对于 css 文件中的图像引用):

<plugin>
    <groupId>com.google.code.maven-replacer-plugin</groupId>
    <artifactId>maven-replacer-plugin</artifactId>
    <version>1.4.1</version>
    <executions>
        <execution>
            <id>anticache</id>
            <phase>prepare-package</phase>
            <goals>
                <goal>replace</goal>
            </goals>
            <configuration>
                <includes>
                    <include>target/classes/**/*.css</include>
                </includes>
                <replacements>
                    <replacement>
                        <token>anti-cache=anti-cache-parameter</token>
                        <value>anti-cache=${maven.build.timestamp}</value>
                    </replacement>
                </replacements>
            </configuration>
        </execution>
    </executions>
</plugin>

只需检查文件模式以匹配您的 JS 文件,然后在您的 JS 文件中:

< link href="~/CSS/file.css#anti-cache=anti-cache-parameter" rel="stylesheet" />

请注意,我在这里没有使用请求参数 (?),而是 #。这是为了避免浏览器缓存受到影响,因为使用请求参数,浏览器缓存将挂在文件的每个版本上。另见:Refresh image with a new one at the same url

现在,如前所述,我们使用它,但它也不是理想的解决方案,但我认为不存在理想的解决方案。

另见缓存在不同浏览器中的行为: https://github.com/podlipensky/RefreshButton