1. 背景介绍
    
    1.1 业务背景
    
    针对海外项目,系统需要灵活支持不同语言的切换
   
     
   
    
    2.设计思路
    
    后台系统负责管理词条,前端负责根据登录语言 获取 对应词条做页面渲染
    
    PS:登录成功获取所有词条缓存浏览器内存,前端每次从内存中获取
    3.使用示例
    
    3.1 引入i18n的核心jar包
    3.2 api调用
    
    I18nUtil工具类
    
    1.自动补全
    
    2.数据拼接
    3.3 liquibase
    
    1)针对已存在language只需维护t_i18n_code表
    
    2)针对新language需要维护t_i18n_language和t_i18n_code
    4. 数据库设计
    
    4.1 语言表t_i18n_language
   
| 字段 | 类型 | 描述 | 
| id | bigint(11) | 主键 | 
| language_code | varchar(16) | 语言编码 | 
| language_name | varchar(16) | 语言名称 | 
4.2 词条表t_i18n_code
| 字段 | 类型 | 描述 | 
| id | bigint(11) | 主键 | 
| i18n_code | varchar(128) | 国际化编码 | 
| desc | varchar(128) | 描述 | 
| zh_cn | varchar(512) | 中文名称 | 
| en_us | varchar(512) | 英语名称 | 
| ja_jp | varchar(512) | 日语名称 | 
5.API 设计
5.1 语言查询(首页初始化调用)
GET /language/query
    请求参数
    
    无参,查所有
    
    响应格式
   
    {
    
   
“code”: 200, // 200 操作成功 500 操作失败 404 参数检验失败 401 暂未登录或token已经过期 403 没有相关权限
“message”:”操作成功”, //额外参考信息
“data”:”[{‘language_code’:’zh_cn’,’language_name’:’中文’}]”
}
5.2 字典查询(首页登录初始化调用)
GET /i18n/query
    请求参数
    
    无参,查所有
    
    响应格式
   
    {
    
   
“code”: 200, // 200 操作成功 500 操作失败 404 参数检验失败 401 暂未登录或token已经过期 403 没有相关权限
“message”:”操作成功”, //额外参考信息
“data”:”[{‘i18n_code’:’lang.linkwise.UserManager.addUser’,’zh_cn’:’用户新增’,’en_us’:’Add user’,’jp_jp’:’ユーザーの追加’}]”
}
 
