一、添加国际化配置文件
在resources下创建名称为i18n的文件夹,并在该文件夹中编写对应的多语言国际化文件login.properties、login_zh_CN.properties和login_en_US.properties
1、login.properties
login.tip=请登录
login.username=用户名
login.password=密码
login.rememberme=记住我
login.button=登录
2、login_zh_CN.properties
login.tip=请登录
login.username=用户名
login.password=密码
login.rememberme=记住我
login.button=登录
3、login_en_US.properties
login.tip=Please sign in
login.username=Username
login.password=Password
login.rememberme=Remember me
login.button=Login
注意,Spring Boot默认识别的语言配置文件为类路径resources下的messages.properties,其他语言国际化文件的名称必须严格按照文件前缀名语言代码国家代码.properties
的形式命名
二、修改全局配置文件
# 配置国际化文件基础名
spring.messages.basename=i18n.login
三、定制区域信息解析器
@Configuration
public class MyLocaleResovel implements LocaleResolver {
// 自定义区域解析方式
@Override
public Locale resolveLocale(HttpServletRequest httpServletRequest) {
// 获取页面手动切换传递的语言参数l
String l = httpServletRequest.getParameter("l");
// 获取请求头自动传递的语言参数Accept-Language
String header = httpServletRequest.getHeader("Accept-Language");
Locale locale = null;
// 如果手动切换参数不为空,就根据手动参数进行语言切换,否则默认根据请求头信息切换
if (!StringUtils.isEmpty(l)) {
String[] split = l.split("_");
locale = new Locale(split[0], split[1]);
} else {
// Accept-Language: en-US,en;q=0.9,zh - CN;q = 0.8, zh;q = 0.7
String[] splits = header.split(",");
String[] split = splits[0].split("-");
locale = new Locale(split[0], split[1]);
}
return locale;
}
@Override
public void setLocale(HttpServletRequest httpServletRequest, @Nullable
HttpServletResponse httpServletResponse, @Nullable Locale locale) {
}
// 将自定义的MyLocalResovel类重新注册为一个类型LocaleResolver的Bean组件
@Bean
public LocaleResolver localeResolver() {
return new MyLocalResovel();
}
}
前端可以通过themeleaf
模板来实现测试