<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
在專案的類路徑resources下建立名稱為i18n的資料夾,並在該資料夾中根據需要編寫對應的多語言國際化檔案login.properties、login_zh_CN.properties和login_en_US.properties檔案
login.properties
login.tip=請登入
login.username=使用者名稱
login.password=密碼
login.rememberme=記住我
login.button=登入
login_zh_CN.properties
login.tip=請登入
login.username=使用者名稱
login.password=密碼
login.rememberme=記住我
login.button=登入
login_en_US.properties
login.tip=Please sign in
login.username=Username
login.password=Password
login.rememberme=Remember me
login.button=Login
login.properties為自定義預設語言組態檔,login_zh_CN.properties為自定義中文國際化檔案,login_en_US.properties為自定義英文國際化檔案
需要說明的是,Spring Boot預設識別的語言組態檔為類路徑resources下的messages.properties;其他語言國際化檔案的名稱必須嚴格按照“檔案字首名語言程式碼國家程式碼.properties”的形式命名
本範例中,在專案類路徑resources下自定義了一個i18n包用於統一設定管理多語言組態檔,並將專案預設語言組態檔名自定義為login.properties,因此,後續還必須在專案全域性組態檔中進行國際化檔案基礎名設定,才能參照自定義國際化檔案
開啟專案的application.properties全域性組態檔,在該檔案中新增國際化檔案基礎名設定,內容如檔案
# 設定國際化檔案基礎名
spring.messages.basename=i18n.login
spring.messages.basename=i18n.login”設定了自定義國際化檔案的基礎名。其中,i18n表示國際化檔案相對專案類路徑resources的位置,login表示多語言檔案的字首名。如果開發者完全按照Spring Boot預設識別機制,在專案類路徑resources下編寫messages.properties等國際化檔案,可以省略國際化檔案基礎名的設定
在完成上一步中多語言國際化檔案的編寫和設定後,就可以正式在前端頁面中結合Thymeleaf模板相關屬性進行國際化語言設定和展示了,不過這種實現方式預設是使用請求頭中的語言資訊(瀏覽器語言資訊)自動進行語言切換的,有些專案還會提供手動語言切換的功能,這就需要客製化區域解析器了
在專案中建立名為com.lagou.config的包,並在該包下建立一個用於客製化國際化功能區域資訊解析器的自定義設定類MyLocalResovel
package com.lagou.config; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.util.StringUtils; import org.springframework.web.servlet.LocaleResolver; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import java.util.Locale; @Configuration public class MyLocalResolver implements LocaleResolver { // 完成自定義 區域解析方式 @Override public Locale resolveLocale(HttpServletRequest request) { // 獲取頁面手動傳遞的語言引數值 : zh_CN en_US "" String l = request.getParameter("l"); Locale locale = null; if (!StringUtils.isEmpty(l)) { // 如果引數不為空,就根據引數值,進行手動語言切換 String[] s = l.split("_"); locale = new Locale(s[0], s[1]); } else { // Accept-Language: zh-CN,zh;q=0.9 String header = request.getHeader("Accept-Language"); String[] split = header.split(","); String[] split1 = split[0].split("-"); locale = new Locale(split1[0], split1[1]); } return locale; } @Override public void setLocale(HttpServletRequest request, HttpServletResponse response, Locale locale) { } // 將自定義的LocaleResolver重新註冊成一個型別為LocaleResolver的Bean元件 @Bean public LocaleResolver localeResolver() { return new MyLocalResolver(); } }
MyLocalResolver自定義區域解析器設定類實現了LocaleResolver介面,並重寫了其中的resolveLocale()方法進行自定義語言解析,最後使用@Bean註解將當前設定類註冊成Spring容器中的一個型別為LocaleResolver的Bean元件,這樣就可以覆蓋預設的LocaleResolver元件。其中,在resolveLocale()方法中,根據不同需求(手動切換語言資訊、瀏覽器請求頭自動切換語言資訊)分別獲取了請求引數l和請求頭引數Accept-Language,然後在請求引數l不為空的情況下就以l引數攜帶的語言為標準進行語言切換,否則就客製化通過請求頭資訊進行自動切換。
需要注意的是,在請求引數l的語言手動切換組裝時,使用的是下劃線“_”進行的切割,這是由多語言組態檔的格式決定的(例如login_zh_CN.properties);而在請求頭引數Accept-Language的語言自動切換組裝時,使用的是短橫線“-”進行的切割,這是由瀏覽器傳送的請求頭資訊樣式決定的(例如Accept-Language: en-US,en;q=0.9,zh-CN;q=0.8,zh;q=0.7)
開啟專案templates模板資料夾中的使用者登入頁面login.html,結合Thymeleaf模板引擎實現國際化功能
<!DOCTYPE html> <html lang="en" xmlns:th="http://www.thymeleaf.org"> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1,shrinkto- fit=no"> <title>使用者登入介面</title> <link th:href="@{/login/css/bootstrap.min.css}" rel="external nofollow" rel="stylesheet"> <link th:href="@{/login/css/signin.css}" rel="external nofollow" rel="stylesheet"> </head> <body class="text-center"> <!-- 使用者登入form表單 --> <form class="form-signin"> <img class="mb-4" th:src="@{/login/img/login.jpg}" width="72" height="72"> <h1 class="h3 mb-3 font-weight-normal" th:text="#{login.tip}">請登入</h1> <input type="text" class="form-control" th:placeholder="#{login.username}" required="" autofocus=""> <input type="password" class="form-control" th:placeholder="#{login.password}" required=""> <div class="checkbox mb-3"> <label> <input type="checkbox" value="remember-me" > [[#{login.rememberme}]] </label> </div> <button class="btn btn-lg btn-primary btn-block" type="submit" th:text="#{login.button}">登入</button> <p class="mt-5 mb-3 text-muted">© <span th:text="${currentYear}">2019</span>-<span th:text="${currentYear}+1">2020</span></p> <a class="btn btn-sm" th:href="@{/toLoginPage(l='zh_CN')}" rel="external nofollow" >中文</a> <!--注意這個路徑是我們controller存取頁面的路徑,不同的是這次攜帶了引數,可以幫我們用來區分locale--> <a class="btn btn-sm" th:href="@{/toLoginPage(l='en_US')}" rel="external nofollow" >English</a> </form> </body> </html>
使用Thymeleaf模板的#{}訊息表示式設定了國際化展示的部分資訊。在對記住我rememberme國際化設定時,需要國際化設定的rememberme在input標籤外部,所以這裡使用了行內表示式[[#login.rememberme}]]動態獲取國際化檔案中的login.rememberme資訊。另外,在表單尾部還提供了中文、English手動切換語言的功能連結,在單擊連結時會分別攜帶國家語言引數向“/”路徑請求跳轉,通過後臺客制化的區域解析器進行手動語言切換。
注:省略了controller控制層處理
點選後
單擊“English”連結進行語言國際化切換時攜帶了指定的“l=zh_CN”引數,後臺客製化的區域解析器設定類MyLocalResovel中的解析方法會根據客製化規則進行語言切換,從而達到了手動切換國際化語言的效果
到此這篇關於Spring boot Thymeleaf設定國際化頁面詳解的文章就介紹到這了,更多相關Spring boot Thymeleaf內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45