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':'ユーザーの追加'}]"
}