内容概要

本篇文章为大家演示如何在微信公众帐号上实现“智能翻译”,本例中翻译功能是通过调用“百度翻译API”实现的。智能翻译是指用户任意输入想要翻译的内容(单词或句子),系统能自动识别用户采用的语言,并将其翻译为其他语言,目前支持的翻译方向:中->英、英->中和日->中。下面我们来看看智能翻译最终做出来的效果:

    

我们通过输入关键词“翻译”或者点击菜单“翻译”能够看到该功能的使用帮助,然后输入“翻译+内容”就能对内容进行翻译了。

百度翻译API介绍

点击查看百度翻译API使用说明,其实这份文档已经说的很详细了,笔者只是将我们调用该接口时最关心的内容摘取出来,主要如下:

1)通过发送HTTP GET请求调用百度翻译API。

2)百度翻译API请求地址:

  http://openapi.baidu.com/public/2.0/bmt/translate

3)调用API需要传递from、to、client_id和q四个参数,描述如下:

key value 描述
from 源语言语种:语言代码或auto 仅支持特定的语言组合,下面会单独进行说明
to 目标语言语种:语言代码或auto 仅支持特定的语言组合,下面会单独进行说明
client_id 开发者在百度连接平台上注册得到的授权API key 请阅读如何获取api key
q 待翻译内容 该字段必须为UTF-8编码,并且以GET方式调用API时,需要进行urlencode编码。

在调用接口前,我们要先获取到api key。获取方式比较简单,根据提示一步步操作就可以,笔者就不再赘述了。
4)对于智能翻译,参数from和to的传都是auto。
4)参数q的编码方式为UTF-8,传递之前要进行urlencode编码。

5)接口返回结果示例如下:

{"from":"en","to":"zh","trans_result":[{"src":"today","dst":"\u4eca\u5929"}]}

返回结果里的中文是unicode编码,需要通过 json_decode进行转换,转换后的示例如下:

{"from": "en","to": "zh","trans_result": [{"src": "today","dst": "今天"},{"src": "tomorrow","dst": "明天"}]
}

JSON处理工具包Gson介绍

Gson是Google提供的用于在Java对象和JSON数据之间进行转换的Java类库。通过使用Gson类库,我们可以将JSON字符串转成Java对象,反之亦然。下载地址:https://code.google.com/p/google-gson/downloads/list,Gson的使用比较简单,直接调用它的方法toJson()或fromJson()就能完成相应的转换,但需要注意的是:在使用Gson将json字符串转换成Java对象之前,需要先创建好与目标Java对象。读者可以在维基百科上学习它的使用示例http://zh.wikipedia.org/wiki/Gson。

代码实现

1)创建与百度翻译API返回的JSON相对应的Java类

  1. import java.util.List;
  2. /**
  3. * 调用百度翻译api查询结果
  4. *
  5. * @author liufeng
  6. * @date 2013-10-21
  7. */
  8. public class TranslateResult {
  9. // 实际采用的源语言
  10. private String from;
  11. // 实际采用的目标语言
  12. private String to;
  13. // 结果体
  14. private List<ResultPair> trans_result;
  15. public String getFrom() {
  16. return from;
  17. }
  18. public void setFrom(String from) {
  19. this.from = from;
  20. }
  21. public String getTo() {
  22. return to;
  23. }
  24. public void setTo(String to) {
  25. this.to = to;
  26. }
  27. public List<ResultPair> getTrans_result() {
  28. return trans_result;
  29. }
  30. public void setTrans_result(List<ResultPair> trans_result) {
  31. this.trans_result = trans_result;
  32. }
  33. }

注意:这里的类名可以任意取,但是成员变量的名字应于翻译 API返回的JSON字符串中的属性名保持一致, 否则将JSON转换成TranslateResult对象时会报错。

TranslateResult类中的trans_result属性是一个ResultPair集合,该类的代码如下:

  1. /**
  2. * 结果对
  3. *
  4. * @author liufeng
  5. * @date 2013-10-21
  6. */
  7. public class ResultPair {
  8. // 原文
  9. private String src;
  10. // 译文
  11. private String dst;
  12. public String getSrc() {
  13. return src;
  14. }
  15. public void setSrc(String src) {
  16. this.src = src;
  17. }
  18. public String getDst() {
  19. return dst;
  20. }
  21. public void setDst(String dst) {
  22. this.dst = dst;
  23. }
  24. }

说明:这两个类的封装是Gson类库所要求的,如果读者不是用Gson解析 json字符串 ,而是用JSON-lib,就没有必要封装这两个类。

2)接口调用 

  1. import java.io.BufferedReader;
  2. import java.io.InputStream;
  3. import java.io.InputStreamReader;
  4. import java.io.UnsupportedEncodingException;
  5. import java.net.HttpURLConnection;
  6. import java.net.URL;
  7. import com.google.gson.Gson;
  8. /**
  9. *
  10. * @author liufeng
  11. * @date 2013-10-21
  12. */
  13. public class BaiduTranslateService {
  14. /**
  15. * 发起http请求获取返回结果
  16. *
  17. * @param requestUrl 请求地址
  18. * @return
  19. */
  20. public static String httpRequest(String requestUrl) {
  21. StringBuffer buffer = new StringBuffer();
  22. try {
  23. URL url = new URL(requestUrl);
  24. HttpURLConnection httpUrlConn = (HttpURLConnection) url.openConnection();
  25. httpUrlConn.setDoOutput(false);
  26. httpUrlConn.setDoInput(true);
  27. httpUrlConn.setUseCaches(false);
  28. httpUrlConn.setRequestMethod("GET");
  29. httpUrlConn.connect();
  30. // 将返回的输入流转换成字符串
  31. InputStream inputStream = httpUrlConn.getInputStream();
  32. InputStreamReader inputStreamReader = new InputStreamReader(inputStream, "utf-8");
  33. BufferedReader bufferedReader = new BufferedReader(inputStreamReader);
  34. String str = null;
  35. while ((str = bufferedReader.readLine()) != null) {
  36. buffer.append(str);
  37. }
  38. bufferedReader.close();
  39. inputStreamReader.close();
  40. // 释放资源
  41. inputStream.close();
  42. inputStream = null;
  43. httpUrlConn.disconnect();
  44. } catch (Exception e) {
  45. }
  46. return buffer.toString();
  47. }
  48. /**
  49. * utf编码
  50. *
  51. * @param source
  52. * @return
  53. */
  54. public static String urlEncodeUTF8(String source) {
  55. String result = source;
  56. try {
  57. result = java.net.URLEncoder.encode(source, "utf-8");
  58. } catch (UnsupportedEncodingException e) {
  59. e.printStackTrace();
  60. }
  61. return result;
  62. }
  63. /**
  64. * 翻译(中->英 英->中 日->中 )
  65. *
  66. * @param source
  67. * @return
  68. */
  69. public static String translate(String source) {
  70. String dst = null;
  71. // 组装查询地址
  72. String requestUrl = "http://openapi.baidu.com/public/2.0/bmt/translate?client_id=AAAAAAAAAAAAAAAAAAAAAAAA&q={keyWord}&from=auto&to=auto";
  73. // 对参数q的值进行urlEncode utf-8编码
  74. requestUrl = requestUrl.replace("{keyWord}", urlEncodeUTF8(source));
  75. // 查询并解析结果
  76. try {
  77. // 查询并获取返回结果
  78. String json = httpRequest(requestUrl);
  79. // 通过Gson工具将json转换成TranslateResult对象
  80. TranslateResult translateResult = new Gson().fromJson(json, TranslateResult.class);
  81. // 取出translateResult中的译文
  82. dst = translateResult.getTrans_result().get(0).getDst();
  83. } catch (Exception e) {
  84. e.printStackTrace();
  85. }
  86. if (null == dst)
  87. dst = "翻译系统异常,请稍候尝试!";
  88. return dst;
  89. }
  90. public static void main(String[] args) {
  91. // 翻译结果:The network really powerful
  92. System.out.println(translate("网络真强大"));
  93. }
  94. }

代码解读:
1)第21-53行封装了一个http请求方法httpRequest(),相信读过之前教程的读者已经很熟悉了。

2)第61-69行封装了一个urlEncodeUTF8()方法,用于对url中的参数进行UTF-8编码。

3)第81行代码中的client_id需要替换成自己申请的api key。

4)第83行代码是对url中的中文进行编码。以后凡是遇到通过url传递中文参数的情况,一定要显示地对中文进行编码,否则很可能出现程序在本机能正常运行,但部署到服务器上却有问题,因为本机与服务器的默认编码方式可能不一样。

5)第88行代码就是调用百度翻译API。

6)第90行代码是使用Gson工具将json字符串转换成TranslateResult对象,是不是发现Gson的使用真的很简单?另外,前面提到过调用百度翻译API返回的json里如果有中文是用unicode表示的,形如“\u4eca\u5929”,那为什么这里没有做任何处理?因为Gson的内部实现已经帮我们搞定了。

公众账号后台调用

在公众账号后台,需要对接收到的文本消息进行判断,如果是以“翻译”两个字开头的,就认为是在使用智能翻译功能,然后将“翻译”两个字之后的内容作为翻译对象,调用API进行翻译;如果输入的只有“翻译”两个字,就提示智能翻译功能的使用指南。关键代码如下:

  1. // 文本消息
  2. if (WeixinUtil.REQ_MESSAGE_TYPE_TEXT.equals(msgType)) {
  3. String content = requestMap.get("Content").trim();
  4. if (content.startsWith("翻译")) {
  5. String keyWord = content.replaceAll("^翻译", "").trim();
  6. if ("".equals(keyWord)) {
  7. textMessage.setContent(getTranslateUsage());
  8. } else {
  9. textMessage.setContent(BaiduTranslateService.translate(keyWord));
  10. }
  11. out.print(WeixinUtil.textMessageToXml(textMessage));
  12. }
  13. }

第7行getTranslateUsage()方法得到的就是智能翻译功能的使用指南,代码如下:

[java] view plaincopy
  1. /**
  2. * Q译通使用指南
  3. *
  4. * @return
  5. */
  6. public static String getTranslateUsage() {
  7. StringBuffer buffer = new StringBuffer();
  8. buffer.append(XiaoqUtil.emoji(0xe148)).append("Q译通使用指南").append("\n\n");
  9. buffer.append("Q译通为用户提供专业的多语言翻译服务,目前支持以下翻译方向:").append("\n");
  10. buffer.append("    中 -> 英").append("\n");
  11. buffer.append("    英 -> 中").append("\n");
  12. buffer.append("    日 -> 中").append("\n\n");
  13. buffer.append("使用示例:").append("\n");
  14. buffer.append("    翻译我是中国人").append("\n");
  15. buffer.append("    翻译dream").append("\n");
  16. buffer.append("    翻译さようなら").append("\n\n");
  17. buffer.append("回复“?”显示主菜单");
  18. return buffer.toString();
  19. }

说明:希望通过本例的学习,除了掌握百度翻译API的调用之外,读者还能够掌握json字符串的解析方法,这样就能够自己学会调用更多互联网上开放的接口

微信公众帐号开发教程第17篇-应用实例之智能翻译相关推荐

  1. [041] 微信公众帐号开发教程第17篇-应用实例之智能翻译

    内容概要 本篇文章为大家演示怎样在微信公众帐号上实现"智能翻译",本例中翻译功能是通过调用"百度翻译API"实现的.智能翻译是指用户随意输入想要翻译的内容(单词 ...

  2. 微信公众帐号开发教程第16篇-应用实例之历史上的今天

    内容概要 本篇文章主要讲解如何在微信公众帐号上实现"历史上的今天"功能.这个例子本身并不复杂,但希望通过对它的学习,读者能够对正则表达式有一个新的认识,能够学会运用现有的网络资源丰 ...

  3. 微信公众帐号开发教程第18篇-应用实例之音乐搜索

    引言及内容概要 微信公众平台支持向用户回复音乐消息,用户收到音乐消息后,点击即可播放音乐.通过音乐消息,公众账号可以实现音乐搜索(歌曲点播)功能,即用户输入想听的音乐名称,公众账号返回对应的音乐(歌曲 ...

  4. [042] 微信公众帐号开发教程第18篇-应用实例之音乐搜索

    引言及内容概要 微信公众平台支持向用户回复音乐消息,用户收到音乐消息后,点击即可播放音乐.通过音乐消息,公众账号可以实现音乐搜索(歌曲点播)功能,即用户输入想听的音乐名称,公众账号返回对应的音乐(歌曲 ...

  5. 微信公众帐号开发教程第6篇-消息及消息处理工具的封装

    本篇内容主要讲解如何将微信公众平台定义的消息及消息相关的操作封装成工具类,方面后期的使用  官方文档 接下来要做的就是将消息请求.回复中定义的消息进行封装,建立与之对应的Java类(Java是一门面向 ...

  6. 微信公众帐号开发教程第1篇-引言(转)

    接触微信公众帐号已经有两个多月的时间了,在这期间,除了陆续完好个人公众帐号xiaoqrobot以外,还带领团队为公司开发了两个企业应用:一个是普通类型的公众帐号,还有一个是会议类型的公众帐号.经过这3 ...

  7. 微信公众帐号开发教程第13篇-图文消息全攻略

    引言及内容概要 已经有几位读者抱怨"柳峰只用到文本消息作为示例,从来不提图文消息,都不知道图文消息该如何使用",好吧,我错了,原本以为把基础API封装完.框架搭建好,再给出一个文本 ...

  8. [025] 微信公众帐号开发教程第1篇-引言

    接触微信公众帐号已经有两个多月的时间了,在这期间,除了陆续完善个人公众帐号xiaoqrobot以外,还带领团队为公司开发了两个企业应用:一个是普通类型的公众帐号,另一个是会议类型的公众帐号.经过这3个 ...

  9. 微信公众帐号开发教程第13篇-图文消息全攻略 -- 转载

    引言及内容概要 已经有几位读者抱怨"柳峰只用到文本消息作为示例,从来不提图文消息,都不知道图文消息该如何使用",好吧,我错了,原本以为把基础API封装完.框架搭建好,再给出一个文本 ...

最新文章

  1. Binder通信模型 :ServiceManager
  2. python的字符串类型本质上_4.3Python数据类型(3)之字符串类型
  3. Gh0st源码学习(一)前期准备工作
  4. java自定义键值对_KV键值对数据类型
  5. java 迁移数据_Java 10迁移建议
  6. 360浏览器怎么添加应用 360安全浏览器应用添加教程
  7. Spring : @ComponentScan注解
  8. 华为业务板块_复盘丨华为Mate30发布 电子板块再爆涨停潮
  9. 一只火鸡带你了解大数据预测(经典)
  10. 同步回调与异步回调区别
  11. UBUNTU 7.04安装后的配置
  12. 基于微信小程序的教学评价平台设计与实现
  13. 直截了当地解释 ERC-3525 与 ERC-1155 的差别
  14. iOS小工具合集-(合一Kit)
  15. Prim算法最小生成树Java超详解
  16. 近期频现NFT新型钓鱼诈骗,用户收到不明OpenSea”高价“空投
  17. 远程视频会议系统/视频调度指挥平台/音视频通话系统EasyRTC在应急指挥领域中的应用
  18. 四年级0基础能学python吗_四年级的孩子,编程零基础,是否可以直接学Python?...
  19. rust地基蓝图在哪找_深海迷航蓝图在哪 深海迷航全蓝图及碎片详细坐标位置介绍...
  20. python爬虫系列--小练爬取花田首页源码

热门文章

  1. flashpaper打印机没有被正确安装_条码打印机有哪些常见问题
  2. (软件工程复习核心重点)第四章总体设计-第一节:总体设计基本概念和设计过程
  3. opencv调试利器ImageWatch的安装使用
  4. Redis 哨兵模式
  5. C++:C++中public protected private关键字用法
  6. 20170513 Python练习册0011过滤敏感词
  7. LintCode 字符串查找
  8. jquery ajax 参数可以序列化
  9. [Codeforces Round #254 div1] C.DZY Loves Colors 【线段树】
  10. [原]那些年整理的Linux常用命令,简单明了