springboot实现国际化非常简单,我们随便搜一搜就能找到详细的教程,我也是先学习了别人的博客,照着人家的做,不过呢我这个人不老实,总想整点不一样的,我没有照着人家的代码一模一样的抄上去,不然我还发现不了这个问题。
首先呢,我也是老老实实写了个类,实现LocaleResolver接口,并重写了resolveLocale方法。代码如下:
public class LocaleResolverImpl implements LocaleResolver {
@Override
public Locale resolveLocale(HttpServletRequest httpServletRequest) {
//获取请求中的language参数
String language = httpServletRequest.getParameter("language");
//获取默认的Locale
Locale locale = Locale.getDefault();
//如果参数不为空,创建新的Locale
if (StrUtil.isNotEmpty(language)){
String[] languageString = language.split("_");
locale = new Locale(languageString[0],languageString[1]);
}
return locale;
}
@Override
public void setLocale(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Locale locale) {
}
}
接下来,我们都知道只需要把这个类交给spring管理就行了,好巧不巧偏偏是这里出了问题:
@Configuration
public class SpringBootConfig {
/**
* 配置undertow容器
* @return
*/
@Bean
public ServletWebServerFactory servletContainer(){
UndertowServletWebServerFactory undertow = new UndertowServletWebServerFactory();
return undertow;
}
/**
* 配置国际化
* @return
*/
@Bean
public LocaleResolver setLocaleResolver(){
return new LocaleResolverImpl();
}
}
大家看这段代码,看起来没毛病是不是,但是这样写完,国际化偏偏不生效。就这一个问题,折磨了我快一天的时间了。后来我是怎么解决的呢?我把人家的代码一模一样的抄了一遍之后,呀,运行成功了。对比我的代码,我发现最可疑的就是这个方法名不一样,果然,把上边配置国际化的方法名改一下,就运行成功了,以下就是改正后的代码:
@Configuration
public class SpringBootConfig {
/**
* 配置undertow容器
* @return
*/
@Bean
public ServletWebServerFactory servletContainer(){
UndertowServletWebServerFactory undertow = new UndertowServletWebServerFactory();
return undertow;
}
/**
* 配置国际化
* @return
*/
@Bean
public LocaleResolver localeResolver(){
return new LocaleResolverImpl();
}
}
没错,就是这个方法名的问题,改成别的就出问题,国际化不生效,它还必须得是localeResolver才行。
为什么会出现这样的情况呢?我当然是得搜一搜资料了。经过我的一番查找发现,这个配置类@Configuration和@Bean还真有点玄机,不知道大家学习Spring的时候还记不记得在spring配置文件xml里配置bean标签的时候有一个属性id。没错,正如你想的那样,在这里,这个方法名就表示这个Bean的id,而springboot就是根据这个id来识别LocaleResolver,如果没有这个id或者你这个id不对,它就会以为你没有自定义这个LocaleResolver而使用它默认的。
今天又是收获满满的一天!