动态替换资源url thymeleaf插件
<dependency>
<groupId>com.github.ayongw</groupId>
<artifactId>thymeleaf-dynamic-url-dialect</artifactId>
<version>1.3.2</version>
</dependency>
解决在开发环境下配置的资源地址能够在不更改程序代码的前提下自动替换为实际的各环境地址。
比如开发环境使用本地地址,生产环境可以将地址自动映射到CDN地址上。加快资源文件加载
spring:
thymeleaf:
dynamic-url:
enable: true
enable-local: true
enable-remote: true
enable-cache: true
localSuffix: .min
minSuffixTypes: css,js
remotePrefix: /static/lib/
remoteUrlMap:
"/demo/local/file.js": "https://demohost.com/file.js"
excludePaths:
- /exclude/file1.js
- /exclude/file2.css
HTML示例片段
<link href="../static/lib/bootstrap/dist/css/bootstrap.css" awdl:href="@{/static/lib/bootstrap/dist/css/bootstrap.min.css}" rel="stylesheet" />
<link href="../static/custlib/sb-admin/css/sb-admin-2.css" awdl:href="@{/static/custlib/sb-admin/css/sb-admin-2.css}" rel="stylesheet" />
根据以上示例,
1.会自动根据配置,将"/static/lib/bootstrap/dist/css/bootstrap.min.css"替换为具体的配置地址。
2.对于本地资源文件"/static/custlib/sb-admin/css/sb-admin-2.css",则会根据配置替换为压缩后的文件地址,一般为"/static/custlib/sb-admin/css/sb-admin-2.min.css"
默认是使用配置文件的形式来替换CDN(远程资源)文件的,但这仅用于测试、开发阶段是可以,真正的生产环境并不是太友好,
如需可以自定义自己的实现,只需要简单的实现接口,并注入到spring中即可。
com.github.ayongw.thymeleaf.dynamicurl.service.DynamicResourceLocationService