Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/xgd16/UniTranslate
基于 go 实现的一个 百度 有道 谷歌 Deepl ChatGPTFree Google Translator API 免费的Google翻译 翻译统一管理接入平台 统一API 调用规范 多平台翻译,调试操作端,权重,多接入 批量翻译 聚合翻译 免费翻译
https://github.com/xgd16/UniTranslate
free-google-translate google-translate google-translate-api unitranslate
Last synced: 3 months ago
JSON representation
基于 go 实现的一个 百度 有道 谷歌 Deepl ChatGPTFree Google Translator API 免费的Google翻译 翻译统一管理接入平台 统一API 调用规范 多平台翻译,调试操作端,权重,多接入 批量翻译 聚合翻译 免费翻译
- Host: GitHub
- URL: https://github.com/xgd16/UniTranslate
- Owner: xgd16
- License: agpl-3.0
- Created: 2023-11-20T12:12:28.000Z (about 1 year ago)
- Default Branch: master
- Last Pushed: 2024-10-12T04:00:54.000Z (3 months ago)
- Last Synced: 2024-10-14T09:34:56.294Z (3 months ago)
- Topics: free-google-translate, google-translate, google-translate-api, unitranslate
- Language: Go
- Homepage:
- Size: 384 KB
- Stars: 54
- Watchers: 1
- Forks: 12
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-gf - uni-translate - 基于 gf 实现的一个 百度 有道 谷歌 Deepl ChatGPT 翻译统一管理接入平台 统一API 调用规范 多平台翻译,调试操作端,权重,多接入 支持web图形化操作调试 (StandAlone Projects)
README
# uniTranslate
[中文](./README.md) | [English](./README_EN.md)
# 项目简介 📒
该项目是一个支持多平台翻译和将翻译结果写入 Redis 缓存的工具。
## 依赖
`MySQL: 8.*` `redis`
可选
`graylog`
## WEB 管理
[UniTranslate-web-console](https://github.com/xgd16/UniTranslate-web-console)
## 功能特点 ✨
- 支持百度,有道,谷歌,Deepl,腾讯,ChatGPT,火山,讯飞,PaPaGo,免费 Google 平台的翻译接入
- 支持设置翻译 API 的等级优先调用配置的低等级 API
- 同一个 API 提供商可配置不限次 可设置为不同等级
- 在配置多个 API 时如果调用当前 API 失败自动切换到下一个
- 可以将翻译过的内容写入 `Redis` `Memory` 缓存重复翻译内容降低翻译 API 重复调用## 批量翻译支持情况
| 平台 | 是否支持批量翻译 | 是否完美支持 | 准确的源语言 | 备注 |
| :--------: | :--------------: |:------:|:------:|:------------------------:|
| 百度 | 是 | 否 | 否 | 不支持精确返回具体每条结果的源语言类型 |
| Google | 是 | 是 | 是 | |
| 有道 | 是 | 否 | 否 | 源语言类型识别不准确 |
| 火山 | 是 | 是 | 是 | |
| Deepl | 是 | 否 | 否 | 源语言类型识别不准确 |
| 讯飞 | 是 | 是 | 是 | 循环实现 |
| PaPaGo | 是 | 否 | 否 | 基于 \n 切割实现 且不可识别不同的源语言类型 |
| ChatGPT | 是 | 否 | 否 | 不在支持源语言类型检测 |
| FreeGoogle | 是 | 是 | 是 | 循环实现 |## 未来支持 (优先级按照顺序,打勾为已实现) ✈️
- [x] 持久化已翻译到 `MySQL`
- [x] web 控制页面
- [x] ChatGPT AI 翻译
- [x] 讯飞翻译
- [x] 更合理安全的身份验证
- [x] 腾讯翻译
- [x] 火山翻译
- [x] PaPaGo
- [x] 支持更多国家语言
- [x] 支持模拟 `LibreTranslate` 翻译接口
- [x] 支持终端交互翻译
- [x] 免费 Google 翻译
- [x] SQL Lite 支持
- [ ] 客户端更多翻译功能支持## 基础类型 🪨
`YouDao` `Baidu` `Google` `Deepl` `ChatGPT` `XunFei` `XunFeiNiu` `Tencent` `HuoShan` `PaPaGo` `FreeGoogle`
## Docker 启动 🚀
```shell
# 项目目录下
docker build -t uni-translate:latest .
# 然后执行 (最好创建一个 network 将 mysql 和 redis 放在同一个下 然后配置里直接用容器名字访问应用即可)
docker run -d --name uniTranslate -v {本机目录}/config.yaml:/app/config.yaml -p 9431:{你在config.yaml中配置的port} --network baseRun uni-translate:latest
```## 终端交互方式
在 `config.yaml` 配置完成后执行
```bash
./UniTranslate translate auto en
```## 配置解析 🗄️
```yaml
server:
name: uniTranslate
address: "0.0.0.0:9431"
cacheMode: redis # redis , mem , off 模式 mem 会将翻译结果存储到程序内存中 模式 off 不写入任何缓存
cachePlatform: false # 执行缓存key生成是否包含平台 (会影响项目启动时自动初始化存储的key)
key: "hdasdhasdhsahdkasjfsoufoqjoje" # http api 对接时的密钥
keyMode: 1 # 模式 1 直接传入 key 做验证 模式 2 使用 key 加密加签数据进行验证
```## 32 位 最后支持版本 (从 v1.5.2 后不在提供对 32 位系统的兼容)
[最后支持的版本 v1.5.1](https://github.com/xgd16/UniTranslate/releases/tag/v1.5.1)
## API 文档 🌍
[在线文档](https://apifox.com/apidoc/shared-335b66b6-90dd-42af-8a1b-f7d1a2c3f351)
[Open Api File](<./uniTranslate%20(统一翻译).openapi.json>)## 接口身份验证 ts 示例
```typescript
import { MD5 } from "crypto-js";/**
*
* @param key 平台设置的key
* @param params 请求参数
* @return 生成的身份验证码
*/
function AuthEncrypt(key: string, params: { [key: string]: any }): string {
return MD5(key + sortMapToStr(params)).toString();
}const sortMapToStr = (map: { [key: string]: any }): string => {
let mapArr = new Array();
for (const key in map) {
const item = map[key];
if (Array.isArray(item)) {
mapArr.push(`${key}:${item.join(",")}`);
continue;
}
if (typeof item === "object") {
mapArr.push(`${key}:|${sortMapToStr(item)}|`);
continue;
}
mapArr.push(`${key}:${item}`);
}return mapArr.sort().join("&");
};const params: { [key: string]: any } = {
c: {
cc: 1,
cb: 2,
ca: 3,
cd: 4,
},
a: 1,
b: [4, 1, 2],
};console.log(AuthEncrypt("123456", params));
```请求示例
```shell
curl --location --request POST 'http://127.0.0.1:9431/api/translate' \
--header 'auth_key: xxxxxxxxx{AuthEncrypt函数结果放在此处}' \
--header 'User-Agent: Apifox/1.0.0 (https://apifox.com)' \
--header 'Content-Type: application/json' \
--data '{
"from": "auto",
"to": "en",
"text": "测试一下",
"platform": "YouDao"
}'
```## 翻译的内容不支持??? 🤔
本程序所有支持的语言根据 [translate.json](./translate.json) 文件进行国家语言**标识**统一使用 _有道_ 翻译 API 标识符作为基准
请根据 _有道_ 翻译 API 文档支持的标识作为基准修改 `translate.json` 文件
## 感谢 [Jetbrains](https://www.jetbrains.com/?from=UniTranslate) 提供免费的 IDE
## Star History
[![Star History Chart](https://api.star-history.com/svg?repos=xgd16/UniTranslate&type=Date)](https://star-history.com/#xgd16/UniTranslate&Date)