接口提示信息国际化, 调用LibreTranslate 离线翻译, 国际化支持

文章目录

背景

将接口返回内容进行翻译, 以适配多语言需求;

实现方式

前端拦截接口返回内容, 调用离线翻译服务进行翻译, 翻译之后再进行相应的提示

参考资料:

离线翻译服务: https://github.com/LibreTranslate/LibreTranslate

步骤

下载并部署离线翻译服务;
  1. 下载链接: https://github.com/jianchang512/ott?tab=readme-ov-file

  2. 解压文件到服务器目录, 已经内置了一部分语言模型, 可以直接使用

  3. 修改 set.ini 为相应的服务地址和端口

  4. 双击 start.exe 启动程序

  5. 使用浏览器访问配置的端口, 检查服务是否正常

    ;第一启动需要下载模型,国内地区需要填写代理地址,比如 v2ray默认地址是 http://127.0.0.1:10809 clash默认http://127.0.0.1:7890
    PROXY=
    ;要绑定到的地址,本机127.0.0.1 或者 192.168.等局域网ip等,默认127.0.0.1
    HOST=127.0.0.1
    ;绑定到的端口
    PORT=9911
    ;使用到的语言模型, zh=中文简 zt=中文繁 en=英语 fr=法语 de=德语 ja=日语 ko=韩语 ru=俄语 es=西班牙语 th=泰国语 it=意大利语 pt=葡萄牙语 ar=阿拉伯语 tr=土耳其语 hi=印度语
    ;如果用不到的语言可以删掉
    LANG=zh,en,zt,fr,de,ja,ko,ru,es,th,it,pt,ar,tr,hi


前端接入
  1. 全局拦截接口响应中的 Message

  2. 调用翻译服务进行翻译

  3. 翻译服务 Api 调用方法

    // 请求示例
    // 翻译错误信息
    const res = fetch('http://xxx:19911/translate', {
    method: 'POST',
    body: JSON.stringify({
    q: error.message, //翻译内容
    source: 'zh', //源语言
    target: locale || 'zh', //目标语言
    format: 'text', // 返回内容的格式, 可选 text | html
    api_key: '' // 默认不开启
    }),
    headers: { 'Content-Type': 'application/json' }
    }).then(res => {
    let resdata = res.json()
    return resdata // 返回值是一个新的promise对象,状态为resolved,所以执行then
    }).then((transResponse) => {
    console.log('transResponse', transResponse)
    if (transResponse && transResponse.translatedText) {
    errMsg = transResponse.translatedText
    }
    }).catch((transError) => {
    console.log(transError)
    }).finally(() => {
    // 失败
    Message({
    message: errMsg,
    type: 'error',
    duration: 5 * 1000,
    onClose: () => {
    msgRecordsMap[errorStatus] = false
    }
    })
    })

    // 响应示例
    {
    "translatedText": "これは間違っています。 書類番号 AdfI 233545756!"
    }

相关推荐
zhanshuo2 分钟前
Python元组黑科技:3招让数据安全暴增200%,学生管理系统实战揭秘!
python
空中湖6 分钟前
免费批量图片格式转换工具
图像处理·python·程序人生
余厌厌厌22 分钟前
go语言学习 第9章:映射(Map)
服务器·学习·golang
Mantanmu36 分钟前
Python训练day40
人工智能·python·机器学习
waving-black39 分钟前
利用frp和腾讯云服务器将内网暴露至外网(内网穿透)
linux·服务器·腾讯云·frp·内网穿透
天天爱吃肉821840 分钟前
新能源汽车热管理核心技术解析:冬季续航提升40%的行业方案
android·python·嵌入式硬件·汽车
ss.li42 分钟前
TripGenie:畅游济南旅行规划助手:个人工作纪实(二十二)
javascript·人工智能·python
stormsha1 小时前
Linux中su与sudo命令的区别:权限管理的关键差异解析
linux·运维·服务器·鸿蒙系统·ux·batch命令
l木本I1 小时前
大模型低秩微调技术 LoRA 深度解析与实践
python·深度学习·自然语言处理·lstm·transformer
哆啦A梦的口袋呀1 小时前
基于Python学习《Head First设计模式》第七章 适配器和外观模式
python·学习·设计模式