IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Java知识库 -> springboot+i8n国际化 -> 正文阅读

[Java知识库]springboot+i8n国际化

1.首先创建一个springboot项目
2.编写配置文件,一定要记得加上最后面四个

# 应用名称
spring.application.name=springboot-i18n
# THYMELEAF (ThymeleafAutoConfiguration)
# 开启模板缓存(默认值: true )
spring.thymeleaf.cache=false
# 检查模板是否存在,然后再呈现
spring.thymeleaf.check-template=true
# 检查模板位置是否正确(默认值 :true )
spring.thymeleaf.check-template-location=true
#Content-Type 的值(默认值: text/html )
spring.thymeleaf.content-type=text/html
# 开启 MVC Thymeleaf 视图解析(默认值: true )
spring.thymeleaf.enabled=true
# 模板编码
spring.thymeleaf.encoding=UTF-8
# 要被排除在解析之外的视图名称列表,?逗号分隔
spring.thymeleaf.excluded-view-names=
# 要运?于模板之上的模板模式。另? StandardTemplate-ModeHandlers( 默认值: HTML5)
spring.thymeleaf.mode=HTML5
# 在构建 URL 时添加到视图名称前的前缀(默认值: classpath:/templates/ )
spring.thymeleaf.prefix=classpath:/templates/
# 在构建 URL 时添加到视图名称后的后缀(默认值: .html )
spring.thymeleaf.suffix=.html
# 应用服务 WEB 访问端口
server.port=8080
spring.messages.basename=i18n.login

3.编写好配置文件之后需要编写页面,这里直接有一个前端页面模板,在templeates目录下创建一个名叫login的html页面。

<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head>
    <meta charset="UTF-8">
    <title>i18n</title>
    <!-- 最新版本的 Bootstrap 核心 CSS 文件 -->
    <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/3.4.1/css/bootstrap.min.css"
      integrity="sha384-HSMxcRTRxnN+Bdg0JdbxYKrThecOKuH5zCYotlSAcp1+c8xmyTe9GYg1l9a69psu" crossorigin="anonymous">
    <style>
        .loginForm{
            height: 350px;
            width: 400px;
            border: cadetblue solid 1px;
            border-radius: 4px;
            box-shadow: 2px 3px gray;
            margin-top: 250px;
            margin-left: auto;
            margin-right: auto;
            padding: 40px 28px;
        }
        .loginForm h2{
            text-align: center;
        }
        .button{
            text-align: center;
        }
    </style>
</head>
<body>

    <div class="loginForm" >
        <h2 th:text="#{login.head}"></h2>
        <form>
            <div class="form-group">
                <label for="exampleInputEmail1" th:text="#{login.username}"></label>
                <input type="email" class="form-control" id="exampleInputEmail1" th:placeholder="#{login.usernamep}">
            </div>
            <div class="form-group">
                <label for="exampleInputPassword1" th:text="#{login.password}"></label>
                <input type="password" class="form-control" id="exampleInputPassword1" th:placeholder="#{login.passwordp}">
            </div>
            <div class="checkbox">
                <label>
                    <input type="checkbox" th:text="#{login.agree}">
                </label>
                <a href="#">&nbsp;&nbsp;&nbsp;&nbsp;xxx安全协议</a><a href="#">xxx隐私协议</a>
            </div>
            <div class="button">
                <input type="submit" class="btn btn-primary" th:value="#{login.sign}"/>
            </div>
            <a class="btn btn-sm left" th:href="@{/login.html(l='zh_CN')}">中文</a>
            <a class="btn btn-sm right" th:href="@{/login.html(l='en_US')}">English</a>
        </form>
    </div>
</body>
</html>

这里·引入了thymeleaf以及bootstrap,pom文件中需要导入thymeleaf依赖。

		<dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-thymeleaf</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

4.弄好之后在resources目录下创建i8n文件夹,之后再其文件夹下创建login.properties,编写以下配置属性

login.username=用户名
login.usernamep=请输入用户名
login.password=密码
login.passwordp=请输入密码
login.agree=同意
login.sign=登入
login.head=用户登入

编写好以后我们再创建login_en_US.properties,以及login_zh_CN.properties.创建好之后login_zh_CN.properties文件的内容和login.properties一样即可,login_en_US.properties文件如下。

login.username=username
login.usernamep=please input your username
login.password=password
login.passwordp=please input your password
login.agree=agree
login.sign=sign in
login.head=User Login

5.视图容器需要经过我们的重新编写,创建config文件加,编写类

public class MyResolve implements LocaleResolver {
    @Override
    public Locale resolveLocale(HttpServletRequest httpServletRequest) {
        String l = httpServletRequest.getParameter("l");
        Locale locale = Locale.getDefault();
        if(!StringUtils.isEmpty(l)){
            String[] s = l.split("_");
            return new Locale(s[0],s[1]);
        }
        return locale;
    }

    @Override
    public void setLocale(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Locale locale) {

    }
}

再编写配置类

@Configuration
public class MyWebMvcConfig implements WebMvcConfigurer {
    @Override
    public void addViewControllers(ViewControllerRegistry registry) {
        registry.addViewController("/login.html").setViewName("login");
    }

    @Bean
    public LocaleResolver localeResolver(){
        return new MyResolve();
    }
}

6.创建controller文件夹,编写类

@Controller
public class LoginController {
    @RequestMapping("/login")
    public String login(){
        return "login";
    }
}

7.启动springboot应用服务,在浏览器输入http://localhost:8080/login
效果如下
登录页面
点击English效果如下
国际化页面
8.以上代码项目结构如下所示
项目结构
9.以上代码已上传至个人github,点击链接即可到达项目链接

  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2022-09-04 00:56:31  更:2022-09-04 01:01:27 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/23 12:55:01-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码