springboot怎么自定义LocaleResolver切换语言
短信预约 -IT技能 免费直播动态提醒
这篇文章主要介绍了springboot怎么自定义LocaleResolver切换语言的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇springboot怎么自定义LocaleResolver切换语言文章都会有所收获,下面我们一起来看看吧。
在下面的Demo中,我用的是thymeleaf模板引擎标签的形式对国际化进行取值。
1、在pom中引入thymeleaf模板引擎
//引入thymeleaf
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>
我这里是以登录界面为例
2、在resources下面创建一个i18n的文件夹,然后创建一个login.properties
login.propertie:默认显示的语言
login.button=登陆
login.password=密码
login.remember=记住我
login.tip=请登陆
login.username=用户名
login_en_US.properties:美国(英语)
login.button=Sign In
login.password=PassWord
login.remember=Remember Me
login.tip=Please sign in
login.username=UserName
login_zh_CN.properties:中文
login.button=登陆
login.password=密码
login.remember=记住我
login.tip=请登陆
login.username=用户名
3、在登录页面通过thymeleaf标签引入国际化
注意:input标签需要用[[]]来进行取值
4、运行项目,将浏览器语言设置为英语(美国)或者中文,我们的页面就会切换语言。
但是这里必须要手动设置浏览器语言才可以实现中英文切换,最终的效果是点击页面上中文和English来进行切换语言,下面来实现这个功能:
1、SpringBoot为我们自动配置了LocaleResolver组件,实现国际化我们需要自定义LocaleResolver才能起作用,代码如下:
**
* Describe: 国际化
* Copyright: ITfxsen
* Date: 2019/10/17
* Time: 16:18
* @author fu.qiang
* @version 1.0
*/
@Configuration
public class MyLocaleResolver implements LocaleResolver {
@Override
public Locale resolveLocale(HttpServletRequest httpServletRequest) {
String l = httpServletRequest.getParameter("l");
if (StringUtils.isEmpty(l)){
Locale locale = Locale.getDefault();
return locale;
}else {
String[] split = l.split("_");
return new Locale(split[0],split[1]);
}
}
2、再将自定义LocaleResolver注入到spring容器中:
@Bean
public LocaleResolver localeResolver(){
return new MyLocaleResolver();
}
3、在页面上使用Thymeleaf模板引擎,对中英文切换的a标签的href属性覆盖:
<a class="btn btn-sm" th:href="@{/login(l='zh_CN')}">中文</a>
<a class="btn btn-sm"th:href="@{/login(l='en_US')}">
English</a>
关于“springboot怎么自定义LocaleResolver切换语言”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“springboot怎么自定义LocaleResolver切换语言”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注编程网行业资讯频道。
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341