一分钟学会SpringBoot配置国际化

1.首先创建一个SpringBoot项目。

2.在resources目录下创建i18n目录。

3.在i18目录下创建三个文件:"login.properties"、"login_en_US.properties"、"login_zh_CN.properties"。

每个文件内容如下:

login.properties <默认语言>

login.btn = 登录login.username = 账号login.password = 密码login.enterUserName = 输入账号login.enterPassword = 输入密码

login_en_US.propertoes <英文>

login.btn = loginlogin.username = usernamelogin.password = passwordlogin.enterUserName = enter usernamelogin.enterPassword = enter password

login_zh_CN.propertes <中文>

login.btn = 登录login.username = 账号login.password = 密码login.enterUserName = 输入账号login.enterPassword = 输入密码

4.在application.properties文件中配置国际化文件名称。

spring.messages.basename= i18n/login

5.在java目录下,创建resolver目录,在当前目录下创建"MyLocaleResolver"类,当前类需要继承"LocaleResolver"接口。

@Configurationpublic class MyLocaleResolver implements LocaleResolver {    @Override    public Locale resolveLocale(HttpServletRequest httpServletRequest) {        // 获取标识        String flag = httpServletRequest.getParameter("flag");        // 配置特定的语言        // Locale.setDefault(Locale.CHINA);        // 配置默认语言        Locale locale = Locale.getDefault();        // 如果不为空        if (!StringUtils.isEmpty(flag)) {            // 对标识通过_进行分割            String[] splits = flag.split("_");            // 创建Locale对象            locale = new Locale(splits[0], splits[1]);        }        return locale;    }
    @Override    public void setLocale(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Locale locale) {    }
     /**     *  将 MyLocaleResolver 交由Spring进行管理     * @return     */    @Bean    public LocaleResolver localeResolver() {        return new MyLocaleResolver();    }

6.在resources目录下的templates目录创建"login.html"文件。

当前链接中的flag='zh_CN',代表的就是语言。

<a th:href="@{/login(flag='zh_CN')}">中文</a>

将xxx.properties中定义好的数据渲染到页面中

th:placeholder="#{login.enterUserName}"

这里我使用了Bootstrap样式库,我们可以自行引入。

<link th:href="@{/webjars/bootstrap/css/bootstrap.min.css}" rel="stylesheet"/><script th:src="@{/webjars/jquery/jquery.min.js}"></script>    

在pom文件中进行引入

<dependency> <groupId>org.webjars</groupId> <artifactId>bootstrap</artifactId> <version>4.3.1</version></dependency><dependency> <groupId>org.webjars</groupId> <artifactId>jquery</artifactId> <version>3.5.1</version></dependency>

login.html

<!DOCTYPE html><html xmlns:th="http://www.thymeleaf.org"><head>    <meta charset="UTF-8">    <title>login</title>    <link th:href="@{/webjars/bootstrap/css/bootstrap.min.css}" rel="stylesheet"/>    <script th:src="@{/webjars/jquery/jquery.min.js}"></script>    <style>        form{            width: 300px;            height: 300px;            margin: 170px auto;            padding: 10px 20px;            text-align: center;            border: 1px solid #e8e8e8;            border-radius: 8px;        }</style></head><body>    <form>        <div class="form-group">            <h5 class="text-area">后台登录</h5>        </div>        <div class="form-group">            <label for="exampleInputEmail1" th:text="#{login.username}"></label>            <input type="email" class="form-control" id="exampleInputEmail1" th:placeholder="#{login.enterUserName}">        </div>        <div class="form-group">            <label for="exampleInputPassword1" th:text="#{login.password}"></label>            <input type="password" class="form-control" id="exampleInputPassword1" th:placeholder="#{login.enterPassword}">        </div>        <div class="button">            <input type="submit" class="btn btn-primary form-control" th:value="#{login.btn}"/>        </div>        <div class="form-group">            <a th:href="@{/login(flag='zh_CN')}">中文</a>            <a th:href="@{/login(flag='en_US')}">英文</a>        </div>    </form></body></html>

7.在java目录下创建controller目录,创建"ViewController"类

@Controllerpublic class ViewController {
    /**     * 登录页面     * @param model     * @return     */    @GetMapping("login")    public String getLogin(){        return "login";    }}

这样我们的国际化就配置完成了。

需要源代码可以关注"SayCode",公众号回复"java国际化",即可领取源代码。

 



  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

香菜的开发日记

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值