经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 程序设计 » ASP.net » 查看文章
.NET应用系统的国际化-多语言翻译服务
来源:cnblogs  作者:Eric zhou  时间:2023/3/20 8:41:22  对本文有异议

上篇文章我们介绍了

.NET应用系统的国际化-基于Roslyn抽取词条、更新代码

系统国际化改造整体设计思路如下:

  1. 提供一个工具,识别前后端代码中的中文,形成多语言词条,按语言、界面、模块统一管理多有的多语言词条
  2. 提供一个翻译服务,批量翻译多语言词条
  3. 提供一个词条服务,支持后端代码在运行时根据用户登录的语言,动态获取对应的多语言文本
  4. 提供前端多语言JS生成服务,按界面动态生成对应的多语言JS文件,方便前端VUE文件使用。
  5. 提供代码替换工具,将VUE前端代码中的中文替换为$t("词条ID"),后端代码中的中文替换为TermService.Current.GetText("词条ID")

本篇文章我们重点和大家分享多语言翻译服务的设计和实现。

一、业务背景

通过上一篇文章,我们把sln解决方案中各个Project下的中文文本,识别成大量的多语言词条。

这些多语言词条临时存储在数据库中,我们要对这个临时结果集,通过多语言翻译服务,按支持的语言,翻译成多语言词条。

对应的类图设计:

 

 

 对应的词条管理界面:

 

 

 因此我们需要一个多语言词条翻译服务,实现词条的批量、快速机器翻译。

二、多语言词条翻译服务

首先,抽象一个翻译接口II18NTermTranslateService

  1. /// <summary>
  2. /// 词条翻译服务接口
  3. /// </summary>
  4. public interface II18NTermTranslateService
  5. {
  6. string Translate(string text, string language);
  7. }

设计一个翻译服务提供者类,通过Facade模式,对外统一提供翻译服务TranslateServiceProvider

  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using System.Threading.Tasks;
  6. using I18N.SPI;
  7. namespace I18N.Translation
  8. {
  9. /// <summary>
  10. /// 翻译服务提供者
  11. /// </summary>
  12. public class TranslateServiceProvider
  13. {
  14. public static II18NTermTranslateService GetTranslateService(Translater translater)
  15. {
  16. switch (translater)
  17. {
  18. case Translater.Youdao:
  19. default:
  20. return new YoudaoTranslateService();
  21. case Translater.Baidu:
  22. return new BaiduTranslateService();
  23. case Translater.Google:
  24. return new GoogleTranslateService();
  25. case Translater.Azure:
  26. return new AzureTranslateService();
  27. }
  28. }
  29. public static II18NTermTranslateService GetYoudaoTranslateService()
  30. {
  31. return new YoudaoTranslateService();
  32. }
  33. public static II18NTermTranslateService GetGoogleTranslateService()
  34. {
  35. return new GoogleTranslateService();
  36. }
  37. public static II18NTermTranslateService GetBaiduTranslateService()
  38. {
  39. return new BaiduTranslateService();
  40. }
  41. public static II18NTermTranslateService GetAzureTranslateService()
  42. {
  43. return new AzureTranslateService();
  44. }
  45. }
  46. }

 这里的Translater是个枚举

  1. public enum Translater
  2. {
  3. Youdao,
  4. Baidu,
  5. Google,
  6. Azure
  7. }

三、多语言词条翻译服务-Azure翻译服务

这里我们使用Azure认知服务中的服务服务,实现上面抽象好的翻译接口

  1. using Newtonsoft.Json;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.Linq;
  5. using System.Net.Http;
  6. using System.Text;
  7. using I18N.SPI;
  8. namespace I18N.Translation
  9. {
  10. /// <summary>
  11. /// Azure翻译服务
  12. /// </summary>
  13. /// <remarks>
  14. /// https://learn.microsoft.com/zh-cn/azure/cognitive-services/translator/text-translation-overview
  15. /// </remarks>
  16. public class AzureTranslateService : II18NTermTranslateService
  17. {
  18. private readonly string _endpoint = "https://api.cognitive.microsofttranslator.com";
  19. private readonly string _key = "XXXXXXXXXXXXXX";
  20. public string Translate(string text, string language)
  21. {
  22. return Post(text, language);
  23. }
  24. private string Post(string text, string language)
  25. {
  26. using (var client = new HttpClient())
  27. {
  28. using (var request = new HttpRequestMessage())
  29. {
  30. var url = $"/translate?api-version=3.0&to={language}";
  31. request.Method = HttpMethod.Post;
  32. request.RequestUri = new Uri($"{_endpoint}{url}");
  33. object[] body = { new { Text = text } };
  34. var requestBody = JsonConvert.SerializeObject(body);
  35. request.Content = new StringContent(requestBody, Encoding.UTF8, "application/json");
  36. request.Headers.Add("Ocp-Apim-Subscription-Key", _key);
  37. var response = client.SendAsync(request).ConfigureAwait(false).GetAwaiter().GetResult();
  38. if (!response.IsSuccessStatusCode)
  39. {
  40. return null;
  41. }
  42. string result = response.Content.ReadAsStringAsync().Result;
  43. var translationResults = JsonConvert.DeserializeObject<TranslationResult[]>(result);
  44. if (translationResults.Length > 0)
  45. {
  46. return translationResults[0].Translations.FirstOrDefault()?.Text;
  47. }
  48. }
  49. }
  50. return null;
  51. }
  52. }
  53. }

这里用到了几个参数类

  1. namespace I18N.Translation
  2. {
  3. public class TranslationResult
  4. {
  5. public DetectedLanguage DetectedLanguage { get; set; }
  6. public Translation[] Translations { get; set; }
  7. }
  8. public class DetectedLanguage
  9. {
  10. public string Language { get; set; }
  11. public float Score { get; set; }
  12. }
  13. public class Translation
  14. {
  15. public string Text { get; set; }
  16. public string To { get; set; }
  17. }
  18. }

四、多语言词条翻译服务-有道云翻译服务

这里我们同时实现了有道云翻译服务

  1. using System;
  2. using System.Linq;
  3. using System.Collections.Generic;
  4. using System.Net.Http;
  5. using System.Web;
  6. using I18N.SPI;
  7. namespace I18N.Translation
  8. {
  9. /// <summary>
  10. /// 有道云翻译服务
  11. /// </summary>
  12. /// <remarks>
  13. /// https://ai.youdao.com/DOCSIRMA/html/%E8%87%AA%E7%84%B6%E8%AF%AD%E8%A8%80%E7%BF%BB%E8%AF%91/API%E6%96%87%E6%A1%A3/%E6%96%87%E6%9C%AC%E7%BF%BB%E8%AF%91%E6%9C%8D%E5%8A%A1/%E6%96%87%E6%9C%AC%E7%BF%BB%E8%AF%91%E6%9C%8D%E5%8A%A1-API%E6%96%87%E6%A1%A3.html
  14. /// </remarks>
  15. public class YoudaoTranslateService : II18NTermTranslateService
  16. {
  17. private string appKey = "XXXXXX";
  18. private string appKeyMY = "XXXXXXXXX";
  19. public string Translate(string text, string language)
  20. {
  21. return Post(text, language);
  22. }
  23. public void Translate(List<I18NTerm> terms, string language)
  24. { }
  25. private string Post(string text, string language)
  26. {
  27. var salt = ToUnixTime(DateTime.Now);
  28. var sign = Encryptor.MD5Hash(appKey + text + salt + appKeyMY).ToUpper();
  29. switch (language.ToLower())
  30. {
  31. case "zh-cn": language = "zh-CHS"; break;
  32. case "en-us": language = "EN"; break;
  33. }
  34. HttpClient client = new HttpClient();
  35. var encodedText = System.Uri.EscapeUriString(text);
  36. var url = @"https://openapi.youdao.com/api?q=" + encodedText + "&from=auto&to=" + language + "&appKey=" + appKey + "&salt=" + salt + "&sign=" + sign;
  37. var result = client.GetStringAsync(url).Result;
  38. //{"returnPhrase":["系统"],"query":"系统","errorCode":"0","l":"zh-CHS2en","tSpeakUrl":"https://openapi.youdao.com/ttsapi?q=system&langType=en&sign=F1945F1CB2D0AEEE40B1277E6C871770&salt=1665580681639&voice=4&format=mp3&appKey=48045ce9f1d5f934&ttsVoiceStrict=false","web":[{"value":["System","lineage","Systematic problem-solving","Windows XP"],"key":"系统"},{"value":["Operating System","OS","Linux"],"key":"操作系统"},{"value":["Domain Name System","Domain Name Server","Domain System"],"key":"域名系统"}],"requestId":"cf134fc6-812b-49ab-a97a-85e56e6697cd","translation":["system"],"dict":{"url":"yddict://m.youdao.com/dict?le=eng&q=%E7%B3%BB%E7%BB%9F"},"webdict":{"url":"http://mobile.youdao.com/dict?le=eng&q=%E7%B3%BB%E7%BB%9F"},"basic":{"phonetic":"xì tǒng","explains":["system"]},"isWord":true,"speakUrl":"https://openapi.youdao.com/ttsapi?q=%E7%B3%BB%E7%BB%9F&langType=zh-CHS&sign=DF2CDF4E306FC8C4F8E224C6E7436B26&salt=1665580681639&voice=4&format=mp3&appKey=48045ce9f1d5f934&ttsVoiceStrict=false"}
  39. var dataResult = Newtonsoft.Json.JsonConvert.DeserializeObject<YoudaoResult>(result);
  40. if (dataResult != null)
  41. {
  42. return dataResult.translation.FirstOrDefault();
  43. }
  44. return null;
  45. }
  46. private long ToUnixTime(DateTime dateTime)
  47. {
  48. var start = new DateTime(1970, 1, 1, 0, 0, 0, DateTimeKind.Utc);
  49. return Convert.ToInt64((dateTime.ToUniversalTime() - start).TotalMilliseconds);
  50. }
  51. }
  52. }

有道云的翻译HttpAPI涉及到了几个参数类

  1. public class YoudaoResult
  2. {
  3. /// <summary>
  4. /// 错误返回码
  5. /// </summary>
  6. public string errorCode { get; set; }
  7. /// <summary>
  8. /// 源语言和目标语言
  9. /// </summary>
  10. public string l { get; set; }
  11. /// <summary>
  12. /// 源语言
  13. /// </summary>
  14. public string query { get; set; }
  15. /// <summary>
  16. /// 源语言
  17. /// </summary>
  18. public List<string> translation { get; set; }
  19. }

 

以上是和大家分享多语言翻译服务的设计和实现。

 

周国庆

2023/3/19

原文链接:https://www.cnblogs.com/tianqing/p/17232559.html

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号