上一篇文章介绍了微信公众平台天气预报功能的开发,实现了微信公众平台的第一个实际应用,在接下来的这一篇文章中,我们将对微信翻译功能进行简单开发,以供读者参考。
二、思路分析
和上一篇查询天气的思路差不多,首先要对用户发送过来的消息进行判断,判断消息里是否含有“翻译”关键字,如果含有,则提取待翻译内容,然后调用网络上开放的翻译API 进行相关翻译。
网络上有很多翻译API,大家可以根据自己的需求进行选择。这里我们选择应用比较广泛的,翻译功能还比较不错的有道翻译API 和百度翻译API,下面对这两种API的相关信息进行分析。
3.1 有道翻译API
3.1.1 API 地址:http://fanyi.youdao.com/openapi
注意:有道提供的API 接口,在下面的测试时,json 数据格式返回不正确,到网上查阅资料,可以正确翻译的地址为 http://fanyi.youdao.com/fanyiapi,这点注意。
3.1.2 申请key
按照要求填写相关信息,这些信息,下面会使用到,所以请认真如实填写。
申请完之后,会在下方生成API key 和keyfrom,使用API 时会用到。
3.1.3 API 使用范例
3.1.4 数据格式
a. xml 格式
http://fanyi.youdao.com/openapi.do?keyfrom=orchid&key=1008797533&type=data&doctype=&version=1.1&q=这里是有道翻译API
0
http://fanyi.youdao.com/openapi.do?keyfrom=orchid&key=1008797533&type=data&doctype=&version=1.1&q=翻译
3.2 百度翻译API
3.2.1 API 地址:http://openapi.baidu.com/public/2.0/bmt/translate
3.2.2 获取api key
开发者在百度连接平台上注册得到的授权API key,详细请参阅:http://developer.baidu.com/wiki/index.php?title=%E5%B8%AE%E5%8A%A9%E6%96%87%E6%A1%A3%E9%A6%96%E9%A1%B5/%E7%BD%91%E7%AB%99%E6%8E%A5%E5%85%A5/%E5%85%A5%E9%97%A8%E6%8C%87%E5%8D%97
3.2.3 API 使用范例
百度翻译API 响应的数据格式为UTF-8编码的PHP数组对应的标准JSON字符串。
trans_result 为一个数组,其中每一个{}就是一个段落,结构如下所示:
段落结果即为trans_result 数组中的一项:
段落结果说明:
经json_decode 后的形式:
翻译消息的格式是 “翻译+待翻译内容”,所以首先截取前两个字,判断是否为 “翻译” 关键字。
使用php函数 mb_substr() 截取,关于该函数的用法上一篇已经讲过,这里不再赘述。
从消息的开头开始截取,截取两个字符,然后加以判断是否为 “翻译” 关键字。
判断是否只输入“翻译”两字,这样输入,没有待翻译内容,则输入的消息也不正确。
接下来进行待翻译内容提取:
从消息的开头第3个字符开始截取,截取202个字符,截取出来的即为待翻译内容。
接着调用函数进行翻译。
= ->youdaoDic( = ->baiduDic();
5.1 有道翻译API
数据接口:
http://fanyi.youdao.com/openapi.do?keyfrom===data==1.1=要翻译的文本
5.1.1 xml 格式
关键代码如下:
youdaoDic( = "orchid"; = "YourApiKey"; = 'http://fanyi.youdao.com/fanyiapi.do?keyfrom='..'&key='..'&type=data&doctype=xml&version=1.1&q='. = ( = -> = ->translation->( == 0 "无法进行有效的翻译"}
说明:
$xmlStyle = simplexml_load_file($url_youdao); // PHP 函数,将XML 文档载入对象中。
$errorCode = $xmlStyle->errorCode; // 获取错误码
$paras = $xmlStyle->translation->paragraph; // 获取翻译内容
5.1.2 json 格式
关键代码如下:
youdaoDic( = "orchid"; = "YourApiKey"; = 'http://fanyi.youdao.com/fanyiapi.do?keyfrom='..'&key='..'&type=data&doctype=json&version=1.1&q='. = ( = json_decode(, = ['errorCode' = ''(( ( 0: = ['translation']['0' 20: = '要翻译的文本过长' 30: = '无法进行有效的翻译' 40: = '不支持的语言类型' 50: = '无效的key': = '出现异常'
说明:
把整个文件读入一个字符串中
$result = json_decode($jsonStyle,true); //对JSON 格式的字符串进行编码
$errorCode = $result['errorCode']; // 获取错误码
$trans = $result['translation']['0']; // 获取翻译结果
5.2 百度翻译API
百度翻译API提供UTF-8编码的PHP数组对应的标准JSON字符串,而且提供了 中->英,中->日,英->中,日->中 四种互译,比有道翻译多了一种。
关键代码如下:
baiduDic(,="auto",="auto" =( ="" = "http://openapi.baidu.com/public/2.0/bmt/translate?client_id=".."&q=".."&from=".."&to=".=json_decode(->language_text( = -> [0]-> language_text((!('file_get_contents' = ( = = 5 curl_setopt (, CURLOPT_URL, curl_setopt (, CURLOPT_RETURNTRANSFER, 1 curl_setopt (, CURLOPT_CONNECTTIMEOUT, = curl_exec( curl_close(
说明:
baiduDic() 函数:
language_text($baidu_url)); // 调用language_text() 函数获取目标URL所打印的内容,然后对JSON 格式的字符串进行编码
trans_result; //获取翻译结果数组
dst; //取第一个数组的dst 结果。
language_text() 函数:
有道翻译-xml 格式:
有道翻译-json 格式:
百度翻译:
注意:该翻译功能放在SAE上能够正常运行,但在BAE上运行不成功,各位有兴趣自行测试一下。
请到QQ群213260412共享里下载使用。
请关注卓锦苏州微信公众帐号,卓锦苏州基于SAE 平台开发,针对于主流的微信功能进行开发测试。
您可以关注卓锦苏州公众帐号进行功能测试,以及获取新的应用开发。
1. 登录微信客户端,朋友们 -> 添加朋友 -> 搜号码 ->zhuojinsz,查找并关注。
2. 扫描二维码:
卓锦苏州功能列表。
We Believe, Great People Share Knowledge...