1、配置文件编写
- 在resource资源文件下新建一个i18n(internationalization)目录,存放国际化配置文件。
- 在其中新建login.properties文件和login_zh_CN.properties,这时候发现IDEA自动识别国际化操作(文件夹图标变了)
- 在这之上再新建一个文件
最后目录变成这样
- 在视图里面开始配置中英文
2、在页面中读取设置的语言(thymeleaf模板语言)
th:text="#{login.tip}"
th:placeholder="#{login.username}"
用上诉方式将值写在标签内
这时候重启tomcat访问页面,页面已经是中文的了(大概默认值是中文吧)
3、配置国际化解析
- 在页面中配置超链接实现点击触发相应语言转换
<!-- 这里传入参数不需要使用 ? 使用 (key=value)-->
<a th:href="@{/index.html(l='zh_CN')}">中文</a>
<a th:href="@{/index.html(l='en_US')}">English</a>
- 需要写一个处理组件类
//可以在链接上携带区域信息
public class MyLocaleResolver implements LocaleResolver {
//解析请求
@Override
public Locale resolveLocale(HttpServletRequest request) {
String language = request.getParameter("l");
Locale locale = Locale.getDefault(); // 如果没有获取到就使用系统默认的
//如果请求链接不为空
if (!StringUtils.isEmpty(language)){
//分割请求参数
String[] split = language.split("_");
//国家,地区
locale = new Locale(split[0],split[1]);
}
return locale;
}
@Override
public void setLocale(HttpServletRequest httpServletRequest,
HttpServletResponse httpServletResponse, Locale locale) {
}
}
为了让我们的区域化信息能够生效,我们需要再配置一下这个组件!在我们自己的MvcConofig下添加 bean
//自定义的国际化组件就生效了
@Bean
public LocaleResolver localeResolver(){
return new MyLocaleResolver();
}
上面代码写在mvc的配置文件类中,该类继承了WebMvcConfigurer,且注解了@Configuration