SpringBoot页面国际化

有的时候,我们所写的页面可能不只有中国人使用,还有可能有外国人使用,这就涉及到中文英文切换,甚至可能多种语言进行切换。这时候页面国际化就派上大用场了。

1、使用前准备

要在idea中同一设置properties配置文件的编码,同一设置为UTF-8。

在这里插入图片描述

2、编写国际化配置文件
  • 在resources资源文件夹下创建一个文件夹i18n

    用来存放国际化转换的信息。

    i18n(其来源是英文单词 internationalization的首末字符i和n,18为中间的字符数)是“国际化”的简称。

  • 在i18n文件夹下创建properties文件(名字根据自己需求自定义)。

    创建一个login.properties,再创建一个login_zh_CN.properties,这时idea就会自动识别到我要进行国际化操作,然后文件夹就会发生变化。自动生成一个文件夹把同类型的国际化properties(就是名字相同部分)包裹住。
    在这里插入图片描述

    如果再需要创建properties文件,就右键自动生成的文件夹new一个就可以了
    在这里插入图片描述

    选择需要的语言
    在这里插入图片描述

    也可以点击加号,自己添加,只需要输入编码即可。例如zh_HK(中国香港)、zh_TW(中国台湾)

  • 编写配置文件

    有两种方式可以选择,一种是每个配置文件都写,另一种是可视化编写。
    在这里插入图片描述

    Text为第一种,比较繁重,工作量大,Resource Bundle为可视化编写,我使用第二种。
    在这里插入图片描述

    依次添加完配置信息,配置文件就可以了。

    其余配置

    默认:

    login.forget=忘记密码?
    login.login=登陆
    login.loginTitle=用户登录
    login.password=密码
    login.remember=记住我
    login.sysName=婚姻登记系统
    login.tip=欢迎登陆
    login.username=账号
    login.verifyCode=验证码
    

    zh_CN中文:

    login.forget=忘记密码?
    login.login=登陆
    login.loginTitle=用户登录
    login.password=密码
    login.remember=记住我
    login.sysName=婚姻登记系统
    login.tip=欢迎登陆
    login.username=账号
    login.verifyCode=验证码
    

    en_US英文:

    login.forget=Forget password?
    login.login=Log in
    login.loginTitle=User Login
    login.password=Password
    login.remember=Remember me
    login.sysName=ROM SYSTEM
    login.tip=Welcome to
    login.username=Username
    login.verifyCode=VerifyCode
    
3、如何使国际化配置文件生效

application.properties中配置国际化配置文件的真实路径,使其得以生效。

#国际化配置文件存放的位置
spring.messages.basename=i18n.login

配置页面国际化值后国际化就可以使用了。Thymeleaf模板使用#{…}取国际化消息

<input type="text" class="form-control" name="username" th:placeholder="#{login.username}">
4、配置国际化解析器

为了能够更自由的在语言之间切换,一般都会有按钮,携带参数传到配置中。

<a class="btn btn-xs" th:href="@{/login.html(l='zh_CN')}">中文</a>
<a class="btn btn-xs" th:href="@{/login.html(l='en_US')}">English</a>

编写一个处理国际化的组件类,需要实现一个接口LocaleResolver

package com.gx.config;

import org.springframework.web.servlet.LocaleResolver;
import org.thymeleaf.util.StringUtils;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.util.Locale;

//消息转换器(国际化)
public class MyLocaleResolver implements LocaleResolver {
    //解析语言请求
    @Override
    public Locale resolveLocale(HttpServletRequest httpServletRequest) {

        //解析请求中携带的语言参数
        String language = httpServletRequest.getParameter("l");

        //获取默认的地区语言
        Locale locale = Locale.getDefault();

        //判断请求中携带的语言参数是否为空,为空使用默认,不为空使用自己设置的语言
        if(!StringUtils.isEmpty(language)){
            //分解参数 zh_CN
            String[] split = language.split("_");
			//国家_地区
            locale = new Locale(split[0],split[1]);
        }

        return locale;
    }
}

最后,需要使得国际化的组件类生效,得要在容器中注册这个类,在配置类@Bean一下

//自定义国际化
@Bean
public LocaleResolver localeResolver(){
    return new MyLocaleResolver();
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
# i18n-demo 基于i18n利用springboot实现后台国际化demo 引入外部依赖:commons-lang3、lombok ## 背景 项目做到尾声,临时需要添加国际化内容,开始只是前台展示的页面添加了国际化支持,后来发现一些后台提示很不友好,遂也选择进行国际化处理。 ## 实现 **Springboot国际化支持的很好,我们就用自带的i18n实现国际化就行。** 1. application.properties配置文件指定messages位置 ``` spring.messages.basename=i18n.message spring.messages.encoding=UTF-8 ``` 通过查看源码我们可以知道,如果不进行配置,默认读取resource下面messages文件,源码如下: ![springboot默认国际化配置读取位置](https://img-blog.csdnimg.cn/20200511183958366.png) 2. 在resource文件夹下面创建我们配置的basename,目录结构如下图: ![三个配置文件](https://img-blog.csdnimg.cn/20200512093846448.png) **其中 message.properties必须要有,其他的配置文件命名格式为:message_语言_国家.properties**,其中语言和国家格式可以查看 java.util.Locale 类中的说明。 3. 自定义重写 LocaleResolver 类的 resolveLocale 方法,代码如下: ``` public class MyLocaleResolverConfig implements LocaleResolver { private static final String PATH_PARAMETER = "lang"; private static final String PATH_PARAMETER_SPLIT = "_"; @Override public Locale resolveLocale(HttpServletRequest request) { String lang = request.getHeader(PATH_PARAMETER); Locale locale = request.getLocale(); if (!StringUtils.isEmpty(lang)) { String[] split = lang.split(PATH_PARAMETER_SPLIT); locale = new Locale(split[0], split[1]); } return locale; } @Override public void setLocale(HttpServletRequest request, HttpServletResponse response, Locale locale) { } } ``` resolveLocale 方法作用就是我们的程序从哪获取指定的语言信息,我这里采用的是从header中获取指定语言,如果没有则采用浏览器 默认的。 还可以从 Session 或 Cookie 中获取。**这里因为我们采取header中获取,所以前端发的请求中 Request Headers 中要有 key 为 lang,value 为 en_US 或 zh_CN 的header。** 4. 将我们自定义的 MyLocaleResolverConfig 作为 Bean 注册进系统中: ``` @Bean public LocaleResolver localeResolver() { return new MyLocale ## 项目备注 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.md文件(如有),仅供学习参考, 切勿用于商业用途。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值