web.xml中Maven占位符不生效問題記錄分析
問題背景
開發(fā)反饋,一個spring mvc的web項目,在web.xml配置的占位符不生效,編譯后還是沒有替換成配置的屬性,如下:
<context-param> <param-name>logbackConfigLocation</param-name> <param-value>classpath:${loagback.xml.path:logback.xml}</param-value> </context-param>
問題分析
先了解下,為什么在Maven中可以通過${xx}這種占位符的方式在編譯期可以獲取到Maven中的Properties屬性信息呢?因為Maven提供了一個插件在起作用
maven-resources-plugin:http://maven.apache.org/plugins/maven-resources-plugin/
Resources Plugin將Resource元素指定的文件復制到輸出目錄。以下三個變體僅在指定或默認資源和輸出目錄元素的方式上有所不同。
Resources插件有三個目標:
resources:resources
將主源代碼的資源復制到主輸出目錄。
此目標通常自動執(zhí)行,因為它默認綁定到流程資源生命周期階段。它始終使用project.build.resources元素指定資源,默認情況下使用project.build.outputDirectory指定復制目標。
resources:testResources
將測試源代碼的資源復制到測試輸出目錄。
此目標通常自動執(zhí)行,因為它默認綁定到process-test-resources生命周期階段。它始終使用project.build.testResources元素指定資源,默認情況下使用project.build.testOutputDirectory指定復制目標。
resources:copy-resources
將資源復制到輸出目錄。
此目標要求您配置要復制的資源,并指定outputDirectory。
以上來自官方的釋義。其實就我們使用來說,這個插件有兩個作用,如下:
- 復制或排除文件:指定源資源目錄下的文件哪些需要編譯到目標目錄
- 過濾$占位符:從Maven Properties中找到占位符中的變量,并替換為Properties中的值
Maven的理念是約定大于配置,所以默認情況下,Maven約定資源目錄是src/main/resources。也就是說即使不在pom.xml加任何Resources配置,只要我們的資源文件放在了
src/main/resources目錄下,就能被maven-resources-plugin管理到,就能替換掉文件中的占位符。
問題定位
如上,我們的web.xml所在目錄為src/main/webapp/WEB-INF下,并不在src/main/resources下,所以不起作用。
還有一個問題是${loagback.xml.path:logback.xml}占位符。Maven對占位符的解析沒有Spring那么智能,不支持占位符中帶條件邏輯的。
問題解決
1、修改占位符為:${loagback.xml.path},調整好每個profile中properties的配置
2、因為web.xml是webapp目錄下的資源,而項目中使用了maven-war-plugin插件來打war包,maven-war-plugin自帶了對webapp下資源的處理。做如下配置即可:
在configuration節(jié)點中添加webResources,如:
或者,簡單點配置filteringDeploymentDescriptors為true即可,如:
maven-war-plugin具體用法請參考官方文檔:http://maven.apache.org/plugins/maven-war-plugin
以上就是web.xml中Maven占位符不生效問題記錄分析的詳細內容,更多關于web.xml中Maven占位符不生效的資料請關注腳本之家其它相關文章!