如何基于OpenShift进行微信公众号开发

如何基于OpenShift进行微信公众号开发

作者:kaige 2015-08-24 15:08:50

云计算 OpenShift是红帽的云开发平台即服务(PaaS)。本文介绍了一个利用OpenShift托管Node.js Web服务进行微信公众号开发的过程。用户只要关注该微信号,发送英文的消息,就能收到中文翻译的回复。下面让我们看一下详细内容。

最近写了一个微信的翻译机器人。用户只要关注该微信号,发送英文的消息,就能收到中文翻译的回复。后台是用Node.js写的,托管在 OpenShift的Paas平台上。翻译过程实际上是调用微软的Bing translation API做的,代码中用到了alexu84的bing-translate和JacksonTian的wechat这两个npm模块。下面把做的过程详细说一下。

1. 微信公众号开发

首先是要到 https://mp.weixin.qq.com 申请一个公众号,并申请成为开发者。目前个人只能申请订阅号,不过订阅号也可以和用户进行消息的交互,这对我们的应用来说足够了。

成为开发者后,微信会给你一个AppID和一个AppSecret,都是一长串的字符串。在开发我们这个应用时,只要用到AppID。

微信客户端会接受用户输入的消息,并把它们转给我们的Web服务。所以微信会要求我们填写我们Web服务的URL地址,Token(令牌),EncodingAESKey(消息加解密密钥)。页面如下图所示:

大致上,填写好信息并提交后,微信服务器会发送一个GET请求到我们的Web服务,携带上Token和一个随机字符串。我们的Web服务必须按照微信开发者文档规定的方式处理这个请求,原样返回这个随机字符串,这样微信服务器才认为我们的Web服务是符合它的接入要求的。微信服务器转发消息给我们自己的Web服务时,是以一个POST消息携带上一个XML数据包,我们的web服务必须解析这个XML数据包才能取得用户发的消息。同样,当我们回复消息给微信服务器时,也要满足其规定的要求。所有这些,在微信的开发者文档中都有详细的描述。

我们当然可以仔细阅读微信的 开发者文档 ,并自己按要求一一实现对应的接口,不过这样太麻烦了:-)。更方便的方式是使用 JacksonTian的微信开发Node.js模块 。使用这个模块,我们只需要填入我们的Token,APPID以及EncodingAESKey,它自动就帮我们处理好微信服务器的验证请求,并允许我们直接获取/回复用户的字符串消息,使我们不用处理XML数据解析等细节问题。在下文我会详细介绍如何使用这个模块。

2. 利用OpenShift托管Node.js Web服务

首先,我们要知道如何用Node.js开发一个Web服务。本文不打算详细介绍这部分内容。基本上,利用express模块,只需几行代码就可以搭起一个Web服务,像这样:

  1. var express = require('express'); 
  2.  
  3. var app = express(); 
  4. app.listen(80); 
  5.  
  6. app.get('/'function (req, res) { 
  7.     res.send("hello world'); 
  8. }); 

搭建好web服务后,我们需要一个拥有公有IP的服务器来运行这些代码。在这方面,我们有很多选择,本文使用OpenShift的应用托管服务。

Youtube上有一个很好的 视频 介绍如何利用OpenShift建立和发布一个Node.js应用,step by step级别的,非常的详细。我们只需要看前30分钟就行了。基本上,Openshift使用git来管理代码开发以及发布的过程。你建立一个应用,OpenShift就在云端为你创建了一个Git仓库,包含一个示例的Node.js应用,并把它在云端运行起来了。我们只要把这个Git仓库的代码 Clone到本地,修改其中的server.js,并把修改好的代码push到云端,Openshift就会自动帮我们停掉当前的示例服务,重新编译代码,重新发布并把我们修改过后的服务运行起来。超级的简单,是不是?

下面是稍微详细一点的步骤:

1)安装OpenShift的客户端工具 rhc ,我们需要利用这个工具创建、发布Node.js应用

2)在command line窗口运行 $ rhc app create nodejs-0.10。这个命令为我们在云端创建了一个Git仓库,把内含的示例应用运行起来,并把代码帮我们clone到了本地。

3)修改server.js,运行:

$ git commit -am

$ git push

我们自己的web服务就在云端运行起来了!

3. 使用bing-translate 和wechat NPM module

这一部分稍微详细介绍一下如何修改server.js,也就是如何使用bing-translate和wechat这两个NPM模块的。

还是直接上代码吧,因为总共就不到40行代码。其中第18行展示了如何使用wechat,第23行展示了如何使用bing-translate。

  1. var express = require('express'); 
  2. var kutil = require('./util/kutil.js'); 
  3. var wechat = require('wechat'); 
  4. var server_port = process.env.OPENSHIFT_NODEJS_PORT || 8080 
  5. var server_ip_address = process.env.OPENSHIFT_NODEJS_IP || '127.0.0.1' 
  6. var client_id_secret = kutil.readJsonFromFile('./res/client_id_secret.json'); 
  7. var wechat_app_config = kutil.readJsonFromFile('./res/wechat_app_config.json'); 
  8. var bt = require('./util/bing-translate.js').init(client_id_secret); 
  9. var app = express(); 
  10. app.listen(server_port, server_ip_address); 
  11. // wechat API 
  12. app.use(express.query()); 
  13. app.use('/wechat', wechat(wechat_app_config, function (req, res, next) { 
  14.   var message = req.weixin; 
  15.   if (message.MsgType == 'text') { 
  16.     var input_word = message.Content; 
  17.     bt.translate(input_word, 'en''zh-CHS'function (translate_err, translate_res) { 
  18.       if (translate_err) { 
  19.         res.reply({ 
  20.           content: 'translation error'
  21.           type: 'text' 
  22.         }); 
  23.         return
  24.       } 
  25.       var translate_result = translate_res["translated_text"]; 
  26.       res.reply({ 
  27.         content: translate_result, 
  28.         type: 'text' 
  29.       }); 
  30.     }); 
  31.   } 
  32. })); 

因为我不想在开源的代码中明文写上我的微信APPID等敏感信息,我又写了一个util从Json文件中读取这些信息。第8行是读Bing translation app的ID和secret,第9行是读微信的APPID等信息。这些信息都分别写在一个Json文件中,格式如下:

  1.     "client_id""your-Bing-translator-app-client_id"
  2.     "client_secret""your-Bing-translator-app-client_secret" 
  3. }
  1.     "token""your_wechat_app_token"
  2.     "appid""your_wechat_app_appid"
  3.     "encodingAESKey""your_wechat_app_AESKey" 

另外,有人可能会注意到我没有直接使用alexu84的bing-translate模块,而是引用了一个本地的bing- translate.js文件。这是因为我对该模块的源文件做了少量的改动,主要是在本地cache了一个Bing translation API的token,这样就不用每次翻译的时候都去调微软的Web API重新拿token了,翻译响应的速度会大大提高。有空的时候我会把这个改动push给alexu84试试看。

4. 关于Microsoft Bing Translation API

大家都注意到在上一部分我们要填入Bing Translation的client ID和client secret。这是因为Bing Translation API也是一个Web服务,我们需要到这个 页面 去申请一个Bing Translation的app,申请好后,就有了我们自己的client ID 和 secret。当然这里可能涉及要注册微软的账号什么的,这里就不赘述了。

***, 我的代码都放到了 GitHub 上,除了把APPID和secret什么的替换成示例的字符串,其他的就和我在OpenShift上发布的代码一模一样了。

参考资源

1. Jose Annunziato 如何利用OpenShift 发布 Node.js应用的视频: https://www.youtube.com/watch?v=wnRtA7a0ST0

2. alexu84: Bing translation API 的Node.js wrapper https://github.com/alexu84/bing-translatehttps://github.com/alexu84/bing-translate

3. JacksonTian: 微信API的Node.js wrapper https://github.com/node-webot/wechat

4. Bing Translation API: http://blogs.msdn.com/b/translation/p/gettingstarted1.aspx

5. 我的代码示例: https://github.com/kaige/KDict/tree/master/openshift_host_code/kdict

博文出处:http://www.cnblogs.com/kaige/p/4659989.html?utm_source=tuicool

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/283955.html<

(0)
运维的头像运维
上一篇2025-05-14 04:17
下一篇 2025-05-14 04:19

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注