勿忘初心做自己 发表于 2024-11-4 13:46:48

【云原生】Docker搭建开源翻译组件Deepl使用详解

目录
一、前言
二、微服务项目使用翻译组件的场景
2.1 多语言用户界面
2.2 业务逻辑中的翻译需求
2.3 满意实时通信的要求
2.4 内容管理系统
2.5 个性化推荐系统
2.6 日志和监控
三、开源类翻译组件解决方案
3.1 国内翻译组件方案汇总
3.1.1 百度翻译
3.1.2 腾讯翻译​​​​​​​
3.1.3 阿里翻译(通用版)
3.1.4 华为翻译
3.1.5 小牛翻译
3.1.6 有道翻译
3.1.7 火山翻译
3.1.8 讯飞翻译
3.2 国外翻译组件方案汇总
3.2.1 谷歌翻译
3.2.2 DeepL翻译
3.2.3 微软翻译
3.2.4 亚马逊翻译
3.3 基于大模型或呆板翻译框架
四、微服务项目中集成翻译组件
4.1 前置预备
4.2 对接小牛翻译
4.2.1 登录控制台
4.2.2 开通API翻译服务
4.2.3 代码集成与调用
4.3 补充阐明
五、本地化摆设翻译工具
5.1 DeeplX-Local 摆设
5.1.1 项目阐明

5.1.2 获取360 apikey
5.1.3 docker摆设过程
5.1.4 效果测试
5.2 DeepLX Serverless 摆设与使用
5.2.1 docker摆设过程
5.2.2 效果测试
5.2.3 在Java代码中集成与使用
六、写在文末

一、前言

在微服务项目开辟中,不少涉及需要举行中英互译,或不同语言举行翻译的场景,以满意现实业务的需求。随着国际化的潮水,许多互联网项目都在致力于打造并兼容多语言从而满意国际化的需求,从而增加了对翻译类技能的深度使用,本篇将介绍一些常用的解决方案,比如国内外开源组件,以及基于Docker本地化摆设开源翻译组件。

二、微服务项目使用翻译组件的场景

在微服务架构的项目中,翻译类技能组件可以被用来解决多种语言环境下的需求,下面枚举了一些通用的场景。

2.1 多语言用户界面

即操纵界面需要支持国际化,具体来说:


[*] 场景描述: 微服务应用需要支持多语言界面,为不同地域的用户提供本地化的体验。
[*] 解决方案: 在前端微服务中集成翻译组件,根据用户的语言偏好动态加载翻译后的文本。
[*] 实现方式: 前端微服务可以调用翻译服务的 API,获取当前语言环境下的 UI 文本。

2.2 业务逻辑中的翻译需求

程序代码中的特定场景下处理逻辑的需要,具体来说:


[*] 场景描述: 在处理业务逻辑时,可能需要将某种语言的数据转换为另一种语言的数据。
[*] 解决方案: 在处理业务逻辑的微服务中调用翻译服务,对数据举行翻译。
[*] 实现方式: 业务逻辑微服务可以通过调用翻译服务的 REST API 来完成翻译操纵。

2.3 满意实时通信的要求

一些实时通信的项目对此有最直接的需求:


[*] 场景描述: 在提供实时通信功能(如谈天室、在线集会等)时,参与者可能来自不同国家和地域。
[*] 解决方案: 在实时通信微服务中集成翻译组件,提供实时翻译功能。
[*] 实现方式: 实时通信微服务可以监听消息队列中的消息,并调用翻译服务举行翻译后再转发给其他参与者。

2.4 内容管理系统

系统对各类内容发布的窗口需要支持多语言:


[*] 场景描述: 内容管理系统需要支持多语言内容的创建、编辑和发布。
[*] 解决方案: 在内容管理微服务中集成翻译组件,支持内容的多语言版本管理。
[*] 实现方式: 内容管理微服务可以提供一个接口,允许用户提交内容翻译请求,并将翻译后的结果保存到数据库中。

2.5 个性化推荐系统

一些偏向推荐类的项目需要支持多语言的场景:


[*] 场景描述: 个性化推荐系统需要根据用户的语言偏好推荐合适的内容。
[*] 解决方案: 在推荐系统的微服务中集成翻译组件,对推荐内容举行翻译。
[*] 实现方式: 推荐系统微服务可以根据用户的语言设置,调用翻译服务对推荐内容举行翻译。

2.6 日志和监控

对于操纵日志展示类的系统,需要能切换不同的操纵语言:


[*] 场景描述: 在日志记录和监控系统中,可能需要记录用户的操纵日志,包罗他们使用的语言。
[*] 解决方案: 在日志和监控系统的微服务中集成翻译组件,支持日志的多语言记录。
[*] 实现方式: 日志记录微服务可以在记录用户操纵日志时,调用翻译服务将日志内容翻译成恰当的语言。

三、开源类翻译组件解决方案

经过多年的发展,市面上也涌现出了许多良好的开源翻译组件可以在系统中直接集成使用,下面汇总了一些国内外的开源类翻译组件解决方案。

3.1 国内翻译组件方案汇总

3.1.1 百度翻译

百度翻译API接口免费翻译额度:


[*] 标准版(5万字符免费/每月)、高级版(100万字符免费/每月-需个人认证,基本都能通过)、尊享版(200万字符免费/每月-需企业认证,门槛高);
[*] 超出免费额度代价:49元/百万字符;
[*] 官方介绍:百度翻译开放平台
https://i-blog.csdnimg.cn/direct/9be9a12a4d3c455a8a8dfc04bb230ec3.png
3.1.2 腾讯翻译

翻译API是一种提供自动翻译功能的云计算服务,具体来说:


[*] API接口免费翻译额度:500万字符免费/每月;
[*] 超出免费额度代价:58元/百万字符,有字符资源包出售;
[*] 官方介绍:呆板翻译 计费概述-购买指南-文档中心-腾讯云


3.1.3 阿里翻译(通用版)

依托阿里巴巴自然语言处理技能和海量数据优势,致力于解决全场景语言障碍,多领域实用,可快速实现一种语言到另一种语言的自动翻译,覆盖全球214种语言。具体来说:


[*] 阿里云翻译API接口免费翻译额度:100万字符免费/每月;
[*] 超出免费额度代价:50元/百万字符,有字符资源包出售;
[*] 官方介绍:呆板翻译的付费模式及具体订价_呆板翻译-阿里云帮助中心
https://i-blog.csdnimg.cn/direct/8b8e68fbb09c4e31b2929166ba2eff1c.png
3.1.4 华为翻译

呆板翻译(Machine Translation)致力于为企业和个人提供不同语种间快速翻译能力,通过API调用即可实现源语言文本到目标语言文本的自动翻译,具体来说:


[*] 华为翻译API接口免费翻译额度: 100万字符免费/每月;
[*] 超出免费额度代价:50元/100万字符;
[*] 官方介绍:呆板翻译语言翻译翻译中心即时通讯视频字幕翻译解决方案-华为云
https://i-blog.csdnimg.cn/direct/85b7cb16cce84a368431a85525474fdd.png
3.1.5 小牛翻译

通过HTTP协议提供400+语言的互译服务,将一段源语言文本转换成目标语言文本,可根据语言参数的不同实现多国语言之间的互译。具体来说:


[*] 小牛翻译API接口免费翻译额度: 20万字符免费/每日(相当于于600万免费每月),新用户还可以领一次100万字符免费福利;
[*] 超出免费额度代价:只按字符资源包出售(例如1000万字符包-1年-500元,5000万字符包-1年-2000元...);
[*] 官方介绍:小牛翻译开放平台 - 呆板翻译找小牛-纯文本翻译、小牛翻译开放平台 - XML翻译
https://i-blog.csdnimg.cn/direct/f6e85cd0e8c44e43b136cb4d039e6a48.png
3.1.6 有道翻译

网易有道旗下一站式人工智能服务提供商,为当局、企业和开辟者提供稳固可靠的基础AI能力,具体来说:


[*] 有道翻译API接口免费翻译额度:无,新用户一次性赠50元免费体验资金;
[*] 超出免费额度代价:48元/百万字符,有字符资源包出售;
[*] 官方介绍:有道翻译产品文档-自然语言翻译服务
https://i-blog.csdnimg.cn/direct/758fd825d91647469ac5fc7ba3eb8d62.png
3.1.7 火山翻译

火山翻译的呆板翻译服务提供快速、稳固、安全的多语言翻译能力,支持包罗文本、图像、音视频文件、实时语音流等场景的翻译,开辟人员可以轻松地集成使用。凭借多年数据积累和技能创新,火山翻译的API服务于消息、视频、游戏、直播、小说、办公、社交等领域,具备独特的优势。具体来说:


[*] 火山翻译API接口免费翻译额度:200万字符免费/每月;
[*] 超出免费额度代价:49元/百万字符;
[*] 官方介绍:产品计费--呆板翻译-火山引擎
https://i-blog.csdnimg.cn/direct/837d32adbbf34d928645b3475939c06a.png

3.1.8 讯飞翻译

基于讯飞自主研发的呆板翻译引擎,支持多达70+个语言与中文互译。实用于翻译机、同声传译等场景,可提供公有云接口及私有化摆设方案。具体来说:


[*] 讯飞翻译API接口免费翻译额度:讯飞翻译普通版 - 200万字符免费包(1年内,该免费包仅能领一次),讯飞翻译niutrans版 - 200万字符免费包(90天内,该免费包仅能领一次);
[*] 超出免费额度代价:只按字符资源包出售(例如100万字符包-1年-48元,2000万字符包-1年-900元...);
[*] 官方介绍:呆板翻译-讯飞开放平台、呆板翻译 niutrans - 语音扩展 - 讯飞开放平台
https://i-blog.csdnimg.cn/direct/12f2feba2d354d9985da869536f730c8.png
3.2 国外翻译组件方案汇总

相比国内的翻译组件,国外的几种翻译组件具有更长的汗青,下面分别做阐明。

3.2.1 谷歌翻译

谷歌翻译(Google Translate)是由谷歌公司开辟的一款在线翻译服务,旨在帮助用户在不同语言之间举行文字翻译,其特点来说:


[*] 广泛的语言支持:

[*] 谷歌翻译支持超过 100 种语言的互译,包罗常见的英语、汉语、西班牙语、法语、德语等,以及一些较为少见的语言。

[*] 实时翻译:

[*] 提供实时翻译功能,用户可以在输入框中键入文字,系统会自动辨认语言并举行翻译。
[*] 实时语音翻译功能,支持语音输入及输出。

[*] 图片翻译:

[*] 支持通过摄像头拍摄或上传图片,辨认图片中的文字并举行翻译。这一功能对于旅游、阅读外文菜单等场合非常有用。

[*] 离线翻译:

[*] 用户可以下载离线语言包,在没有网络毗连的情况下也能举行翻译。

[*] API 接口:

[*] 提供了 Google Cloud Translation API,允许开辟者将谷歌翻译的功能集成到自己的应用程序中。

翻译包阐明:


[*] Google翻译API接口免费翻译额度: 50万字符免费/每月,新用户赠300美元(90天内有效);
[*] 超出免费额度代价:20美元(约140元)/百万字符;
[*] 官方介绍:https://cloud.google.com/translate/?hl=zh-cn

3.2.2 DeepL翻译

DeepL 是一款高质量的在线翻译服务,以其精彩的翻译质量和自然流畅的翻译效果而闻名。与谷歌翻译相比,DeepL 在某些方面表现更为精彩,特别是在处理欧洲语言方面。以下是关于 DeepL 翻译的一些具体介绍:


[*] 高质量翻译:

[*] DeepL 使用先辈的神经网络呆板翻译技能,能够生成接近人工翻译的质量。它特别擅优点理复杂的句子结构和上下文相关的翻译。

[*] 广泛的语言支持:

[*] DeepL 支持多种语言,包罗但不限于英语、德语、法语、西班牙语、意大利语等等。

[*] 实时翻译:

[*] DeepL 提供实时翻译功能,用户可以在输入框中键入文字,系统会自动辨认语言并举行翻译。

[*] 文档翻译:

[*] 用户可以直接上传文档(如 Word、PDF、PPT 等),DeepL 会对其举行翻译并保持原文档格式不变。

[*] API 接口:

[*] 提供了 DeepL API,允许开辟者将 DeepL 的翻译功能集成到自己的应用程序或网站中。API 支持多种编程语言,包罗 Python、Java、C# 等。

[*] 用户界面友好:

[*] DeepL 的网页版和移动应用界面简洁易用,支持拖放文件、文本高亮等功能,方便用户举行翻译。

[*] 个性化翻译记忆库:

[*] DeepL Pro 版本允许用户创建自己的翻译记忆库,保存常用的翻译内容,以便在未来重复使用。

翻译包阐明:


[*] DeepL翻译API接口免费翻译额度:50万字符免费/每月(API Free版本,超出50万后无法使用,需使用API Pro版本);
[*] 超出免费额度代价:25美元(约180元)/百万字符(Pro版本才可以使用,每月固定5.49美元套餐费,例如新加坡地域),申请开通困难可以实验某宝;
[*] 官方介绍:DeepL翻译API|呆板翻译技能
3.2.3 微软翻译

微软翻译(Microsoft Translator)是由微软公司提供的一项在线翻译服务,旨在帮助用户在多种语言之间举行文本翻译。其主要特点如下:


[*] 广泛的语言支持:

[*] 微软翻译支持超过 60 种语言的互译,包罗常见的英语、汉语、西班牙语、法语、德语等,以及一些较为少见的语言,如阿塞拜疆语、哈萨克语等。

[*] 实时翻译:

[*] 提供实时翻译功能,用户可以在输入框中键入文字,系统会自动辨认语言并举行翻译。
[*] 实时语音翻译功能,支持语音输入及输出。

[*] 图片翻译:

[*] 支持通过摄像头拍摄或上传图片,辨认图片中的文字并举行翻译。这一功能对于旅游、阅读外文菜单等场合非常有用。

[*] 离线翻译:

[*] 用户可以下载离线语言包,在没有网络毗连的情况下也能举行翻译。

[*] 文档翻译:

[*] 支持上传文档(如 Word、Excel、PowerPoint、PDF 等),并将文档内容翻译成所需的目标语言。

[*] API 接口:

[*] 提供了 Azure Translator Text API,允许开辟者将微软翻译的功能集成到自己的应用程序中。API 支持多种编程语言,包罗 C#、Java、Python、Node.js 等。

[*] 个性化设置:

[*] 用户可以根据需要选择不同的发音风格和翻译风格,以顺应不同的场景需求。

[*] 集成工具

[*] 微软翻译可以与 Office 等微软产品无缝集成,提供更便捷的翻译体验。

翻译包阐明:


[*] 微软翻译API接口免费翻译额度:200万字符免费/每月(新用户前12个月才有);
[*] 超出免费额度代价:10美元(约71元)/百万字符;
[*] 官方介绍:Translator - 翻译服务型软件 | Microsoft Azure
3.2.4 亚马逊翻译

亚马逊翻译(Amazon Translate)是亚马逊云服务(AWS)提供的一项呆板翻译服务,旨在为企业和个人用户提供高质量的文本翻译。其主要特点如下:


[*] 广泛的语言支持:

[*] 亚马逊翻译支持多种语言的互译,包罗常见的英语、汉语、西班牙语、法语、德语、意大利语、日语、韩语、葡萄牙语等。具体支持的语言列表会随着服务的发展而更新。

[*] 高质量翻译:

[*] 亚马逊翻译采用神经网络呆板翻译(Neural Machine Translation, NMT)技能,能够生成自然流畅的翻译结果,尤其得当处理长句和复杂的语法结构。

[*] 实时翻译:

[*] 提供实时翻译功能,用户可以在输入框中键入文字,系统会自动辨认语言并举行翻译。

[*] 文档翻译:

[*] 支持上传文档(如 PDF、Word、Excel、PowerPoint 等),并将文档内容翻译成所需的目标语言。

[*] API 接口:

[*] 提供了 Amazon Translate API,允许开辟者将翻译功能集成到自己的应用程序或网站中。API 支持多种编程语言,包罗 Java、Python、Node.js 等。

[*] 高度可扩展性:

[*] 作为 AWS 的一部分,亚马逊翻译具有高度的可扩展性,可以轻松处理大量翻译请求,得当大规模的企业级应用。

[*] 集成与自动化:

[*] 可以与其他 AWS 服务集成,如 Amazon S3、Amazon Lex、Amazon Polly 等,提供更加丰富的功能组合。

翻译包阐明:


[*] Amazon翻译API接口免费翻译额度:200万字符免费/每月(新用户前12个月才有);
[*] 超出免费额度代价:15美元(约107元)/百万字符;
[*] 官方介绍:Amazon Translate 神经网络呆板翻译_自然语言处理-AWS云服务

3.3 基于大模型或呆板翻译框架

上述提供的国内外开源翻译组件你仍然觉得对接麻烦,或者担心存在一定的数据安全风险,也可以考虑基于开源的大模型,或一些成熟的呆板学习框架举行本地化摆设,通过一定的练习之后用于提供翻译服务。下面提供几种可用于本地摆设的翻译类呆板学习框架:


[*] OpenNMT

[*] 描述: OpenNMT 是一个开源的神经网络呆板翻译框架,支持多种语言对。
[*] 用途: 得当有呆板学习经验的开辟者,需要自己练习模型。
[*] 集成方式: 通过 REST API 或者摆设为微服务后调用。

[*] Marian NMT

[*] 描述: Marian 是一个快速的神经呆板翻译框架,支持 GPU 和 CPU。
[*] 用途: 同样得当有呆板学习经验的开辟者,需要自行练习模型。
[*] 集成方式: 可以通过 REST API 调用。

[*] Apertium

[*] 描述: Apertium 是一个轻量级的开源呆板翻译平台,专注于资源匮乏的语言对。
[*] 用途: 提供了一些预练习的模型,包罗一些不太常见的语言对。
[*] 集成方式: 可以通过 HTTP API 调用,也可以直接摆设本地服务。



四、微服务项目中集成翻译组件

接下来在演示怎样在springboot项目中集成常用的翻译组件举行使用。

4.1 前置预备

提前搭建一个springboot工程,导入下面基础依靠
                <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
      </dependency>

      <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <scope>provided</scope>
      </dependency>

      <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>fastjson</artifactId>
            <version>2.0.35</version>
      </dependency>

      <dependency>
            <groupId>com.squareup.okhttp3</groupId>
            <artifactId>okhttp</artifactId>
            <version>4.12.0</version>
      </dependency> 4.2 对接小牛翻译

官方主页:小牛翻译开放平台 - 呆板翻译找小牛
4.2.1 登录控制台

登录官网之后注册一个账号,然后从控制台获取apikey的信息,以及API层面的对接文档,如下:
https://i-blog.csdnimg.cn/direct/b5bb8fd4841c4b2683fd0ae3c2dc99df.png
4.2.2 开通API翻译服务

点击开通服务
https://i-blog.csdnimg.cn/direct/80bc1f21fbe94dd1a9683e09aad6456e.png
开通之后,会产生 api-key和appid,请妥善保管
https://i-blog.csdnimg.cn/direct/846821a9c49541f0a6f582c3b14f106d.png
点击查看开辟文档:小牛翻译开放平台 - 呆板翻译找小牛,即可看到如下具体的文档对接阐明。
https://i-blog.csdnimg.cn/direct/c72616c23f204f8bb7b988309aba0027.png

4.2.3 代码集成与调用

以文本翻译API为例举行操纵,你也可以翻到每个API的最后,里面提供了对接API的代码示例
https://i-blog.csdnimg.cn/direct/d09a9437f9a34487bc0e9bc4cc16859e.png
完整的代码如下:
package com.congge.translate;

import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.net.HttpURLConnection;
import java.net.URL;
import java.nio.charset.StandardCharsets;

public class NiuTransAPIExample {

    public static void main(String[] args) {
      String requestUrl = "http://api.niutrans.com/NiuTransServer/translation";
      String apiKey = "你的apikey";
      String textToTranslate = "你好,世界!";
      String sourceLang = "zh";
      String targetLang = "en";
      try {
            URL url = new URL(requestUrl);
            HttpURLConnection connection = (HttpURLConnection) url.openConnection();
            // 设置请求类型为 POST
            connection.setRequestMethod("GET");
            // 添加请求头
            connection.setRequestProperty("Content-Type", "application/x-www-form-urlencoded");
            // 设置允许输出
            connection.setDoOutput(true);
            // 构造请求参数
            String requestBody = "from=" + sourceLang + "&to=" + targetLang + "&src_text=" + textToTranslate +"&apikey="+apiKey;
            // 写入请求数据
            try (OutputStream os = connection.getOutputStream()) {
                byte[] input = requestBody.getBytes(StandardCharsets.UTF_8);
                os.write(input, 0, input.length);
            }
            // 获取响应码
            int responseCode = connection.getResponseCode();
            System.out.println("Response Code : " + responseCode);
            // 读取响应数据
            try (BufferedReader br = new BufferedReader(
                  new InputStreamReader(connection.getInputStream(), StandardCharsets.UTF_8))) {
                StringBuilder response = new StringBuilder();
                String responseLine;
                while ((responseLine = br.readLine()) != null) {
                  response.append(responseLine.trim());
                }
                System.out.println("Response Body: " + response.toString());
            }
      } catch (Exception e) {
            e.printStackTrace();
      }
    }
} 运行上面的代码,控制台可以看到能够正常将中文翻译成英文
https://i-blog.csdnimg.cn/direct/021568167679498283f1545fe07fdbe7.png
4.3 补充阐明

上面演示了其中一种市面上的开源翻译组件的对接过程,像腾讯云、阿里云、亚马逊等翻译组件的对接过程也是大同小异,有爱好的同学可以用类似的方式对接并在程序中集成即可,要注意的是,针对新注册的账户,不同的厂商提供了一定的免费额度以供使用,但是假如你的现实业务中翻译量很大,免费的额度不够用,发起还是开通付费包,避免使用过程中因为额度问题造成了业务上的影响。

五、本地化摆设翻译工具

假如上面的方式都不能满意你的需求,最后再提供一种可行的解决方案,即本地私有化摆设开源的翻译工具举行使用,固然,这种方式根据你的场景不同,在摆设的本钱上也不太一样,比如你只是做简单的开辟测试,跟你想大规模使用翻译,在组件的选择上也会存在差异,下面以deepl的一个开源工具插件为例,举行本地化摆设和对接使用的操纵演示。

5.1 DeeplX-Local 摆设

项目地址:GitCode - 全球开辟者的开源社区,开源代码托管平台
https://i-blog.csdnimg.cn/direct/bbb856d0351048d7871b88dda8cb4b6b.png

5.1.1 项目阐明

ycvk/deeplx-local 是一个基于 DeepL 翻译引擎的本地摆设解决方案,它使开辟者和用户能够无需外部 API 密钥,在本地环境中运行高效、低耽误的翻译服务。该项目设计用于支持大规模文本的翻译,并提供了智能的文本拆分与并行处理能力,确保了翻译任务的流畅举行。它支持一键启动并通过 Docker 化简化了摆设流程,非常得当希望拥有私有翻译服务的个人或企业。


5.1.2 获取360 apikey

使用docker摆设deeplx-local时,为了确保能够正常使用,还需要在docker运行的参数里面添加360_api_key,否则无法正常运行,通过git项目中的链接跳转到quake.360举行一下注册,然后在自己的控制台上即可获取这个apikey
https://i-blog.csdnimg.cn/direct/dd3da1b4b60c4e478511701dfa920e92.png
   需要注意的是,这种方式是有次数限定的

5.1.3 docker摆设过程

对于希望通过 Docker 快速摆设的用户,只需执行以下命令:
docker run -itd --name deeplx-local -p 8081:62155 -e 360_api_key="你的360apikey" neccen/deeplx-local:latest 这将启动容器并将服务袒露在本地的 8080 端口,翻译接口可通过 http://localhost:8080/translate 访问。如需自定义路由,可以添加环境变量 -e route=你的路由名称,例如:
docker run -itd --name deeplx-local -p 8081:62155 -e route=my-translate -e 360_api_key="你的360apikey" neccen/deeplx-local:latest https://i-blog.csdnimg.cn/direct/55e0a80fe3454b3d951feea8638f907b.png

5.1.4 效果测试

摆设成功后,使用下面的命令做一下测试
curl -X POST http://localhost:8081/translate \
   -H 'Content-Type: application/json' \
   --data '{"text":"你好,世界!","targetLang":"en"}' 可以看到能够正常举行翻译
https://i-blog.csdnimg.cn/direct/cecd675e4ae7401aa6f309479f4b3d3f.png


5.2 DeepLX Serverless 摆设与使用

这是一个基于 DeepL翻译API 的无服务器函数摆设项目,旨在提供一个可直接对接的免费翻译解决方案,很得当需要在无服务器环境中集成DeepL翻译服务的开辟者使用。

与原项目DeepLX的区别在于利用了无服务器函数(边沿函数)请求IP不固定的特性,有效避免了Error 429请求太频仍的报错;
   固然因此不会立马被暂时封禁,但也请不要滥用!现在我摆设在vercel上会有流量限定,假如您有大量内容需要翻译,请购买DeepL的付费版,当前项目使用的free接口会受到DeepL政策限定由于现在项目未对pro接口举行适配,所以现在还只能使用free接口,不过在将来会完满
5.2.1 docker摆设过程

运行下面的命令启动容器
docker run -d -p 8085:6119 ghcr.io/guobao2333/deeplx-serverless https://i-blog.csdnimg.cn/direct/a1548681a32146e69ad723a11e955bfa.png
5.2.2 效果测试

使用下面的命令举行测试
curl --location --request POST 'http://localhost:8085/translate' --header 'Content-Type: application/json' --data '{"text": "你好,世界!", "source_lang": "zh", "target_lang": "en"}' 也能正确得到翻译结果
https://i-blog.csdnimg.cn/direct/86046571d5d44e8dadd34248ca865eac.png
5.2.3 在Java代码中集成与使用

基于上述搭建的本地deepl的翻译服务,下面通过代码调用测试一下,下面是调用的完整代码
package com.congge.translate;
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.net.HttpURLConnection;
import java.net.URL;
import java.nio.charset.StandardCharsets;

public class DeepLLocalTest {

    public static void main(String[] args) {
      String requestUrl = "http://部署的IP:8085/translate";
      String requestJson = "{\"text\": \"Hello , World!\", \"source_lang\": \"en\", \"target_lang\": \"zh\"}";
      try {
            URL url = new URL(requestUrl);
            HttpURLConnection connection = (HttpURLConnection) url.openConnection();
            // 设置请求类型为 POST
            connection.setRequestMethod("POST");
            // 添加请求头 Content-Type
            connection.setRequestProperty("Content-Type", "application/json");
            // 设置允许输出
            connection.setDoOutput(true);
            // 写入请求数据
            try (OutputStream os = connection.getOutputStream()) {
                byte[] input = requestJson.getBytes(StandardCharsets.UTF_8);
                os.write(input, 0, input.length);
            }
            // 获取响应码
            int responseCode = connection.getResponseCode();
            System.out.println("Response Code : " + responseCode);
            // 读取响应数据
            try (BufferedReader br = new BufferedReader(
                  new InputStreamReader(connection.getInputStream(), StandardCharsets.UTF_8))) {
                StringBuilder response = new StringBuilder();
                String responseLine;
                while ((responseLine = br.readLine()) != null) {
                  response.append(responseLine.trim());
                }
                System.out.println("Response Body: " + response.toString());
            }
      } catch (Exception e) {
            e.printStackTrace();
      }
    }

} 运行上面的代码,通过控制台可以看到已经得到正确的翻译结果
https://i-blog.csdnimg.cn/direct/7b0fa7e7b6c34228a1d44e64f195cde3.png

六、写在文末

本文通过较大的篇幅具体结束了常用的翻译组件的使用,最后以deepl为例举行本地化摆设,并联合代码举行演示操纵,希望对看到的同学有用,本篇到此结束,感谢观看。


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页: [1]
查看完整版本: 【云原生】Docker搭建开源翻译组件Deepl使用详解