使用Nodejs开发微信公众号后台服务实例


Posted in NodeJs onSeptember 03, 2014

摘要:

微信,庞大的用户基数,极强的用户粘性,在近两年吸引了无数的开发者注意力。 Nodejs,近两年发展非常快的开发工具,尤其适合构建移动后台。本文就以笔者自己开发的实例,来描述如何基于Nodejs开发属于自己的微信公众号。在这个实例中,主要使用到了express, wechat, mongodb, monk等模块。

前期准备:

1.申请微信公众号,前往 https://mp.weixin.qq.com/  申请,这里不做过多阐述。

2. 购买服务器, 这里推荐Amazon的EC2,首次用户可选择micro instance,一年免费,申请很方便,只需输入自己的信用卡信息即可,只是整个过程是全英文,不过年免费呦,多花点时间也是值得的。

安装NodeJs开发环境:

1.  yum -y install gcc

2.  yum -y install gcc-c++

3.  yum -y install make automake

4.  wget http://nodejs.org/dist/v0.10.29/node-v0.10.29.tar.gz

5.  tar -xvzf node-v0.10.29.tar.gz 

6.  cd  解压目录

7. ./configure 

8.  make

9.  make install

安装Mongodb:
1. wget http://downloads.10gen.com/linux/mongodb-linux-x86_64-enterprise-amzn64-2.6.3.tgz

2. tar -xvzf mongodb-linux-x86_64-enterprise-amzn64-2.6.3.tgz 

3. sudo cp -R -n  mongodb-linux-x86_64-enterprise-amzn64-2.6.3 /usr/local/mongodb

实例介绍:

笔者所在班级组了个足球队,大家统一把钱交到队长手里,由队长支付每次费用,并记录每人费用和余额并通知大家。由于不是每次所有人都能来,而费用只能由参加活动的人以AA方式平摊,记录起来比较麻烦。于是笔者就做了个微信公众号,每次只需要输入活动消费金额和选择参与人数,即可自动生成每人花费和余额,此后把明细发到微信群里,每个人就可以看见了。 

在这个实例中,笔者实际上搭建了一个微网站,通过Web页面来记录或显示活动花费和余额。微信公众号就相当于在用户微信和微网站之间搭起了一个桥梁,当微信用户关注笔者的公众账号时,通过微信公众平台开发者模式,即可自动给微信用户回复使用帮助。在帮助里,包含了操作相应的web link,只需要点击即可进入相应页面。

构建微信公众号后台服务:

万事具备,只欠开发了:)

开始之前,先简要介绍下express和wechat 两个模块:
express - 优秀的Web开发框架, 使用express,可以非常快速的搭建自己的网站。由于微信服务器会通过HTTP Post请求来和开发者服务器交互,所以需要使用express框架。

下面是有新用户关注时的log, 103.7.30.84为微信服务器的IP地址。

103.7.30.84 POST /wechat?signature=8a8e408fdae6bbdd6e470af98865a5f993cea283×tamp=1408610461&nonce=1572142586 2 200

wechat -  封装了和微信服务器交互的细节,使开发者只需关注自己的业务即可。

首先,我们要安装express 并使用express 来创建工程:

1. npm install -g express

2. express -e your_project    参数 -e 表明使用ejs 引擎,无参数默认使用jade 引擎。

3. cd your_project && npm install

安装后的目录结构如下:

[ec2-user@ip-172-31-2-188 your_project]$ ls

app.js  bin  node_modules  package.json  public  routes  views

接下来安装wechat:
1. npm install wechat

微信开发者模式配置:

配置URL和token,示例如下:

使用Nodejs开发微信公众号后台服务实例

微信服务器接入认证和自动回复:

修改app.js,相应代码如下:

app.use('/users', users);

app.use('/weixin', weixin);
app.use(express.query()); // Or app.use(express.query());

app.use('/wechat', wechat('hchismylove', function (req, res, next) {

 // 微信输入信息都在req.weixin上

 var message = req.weixin;

 console.log(message);
 if((message.MsgType == 'event') && (message.Event == 'subscribe'))

 {

  var refillStr = "<a href=\"http://your_IP/weixin/refill?weixinId=" + message.FromUserName + "\">1. 点击记录团队充值</a>"

      

  var consumeStr = "<a href=\"http://your_IP/weixin/consume?weixinId=" + message.FromUserName + "\">2. 点击记录团队消费</a>"
  var deleteStr = "<a href=\"http://your_IP/weixin/delete?weixinId=" + message.FromUserName + "\">3. 点击回退记录</a>"      
  var historyStr = "<a href=\"http://your_IP/weixin/history?weixinId=" + message.FromUserName + "\">4. 点击查询历史记录</a>"

      

  var emptyStr = "          ";    

  var replyStr = "感谢你的关注!" + "\n"+ emptyStr + "\n" + refillStr + "\n"+ emptyStr + "\n" + consumeStr 

          + "\n"+ emptyStr + "\n" + deleteStr + "\n"+ emptyStr + "\n" + historyStr;

  res.reply(replyStr);

 }

}));

通过下面这行代码即可实现微信服务器接入认证:

app.use('/wechat', wechat('your_token', function (req, res, next) {

如下代码实现了当新用户关注时,自动发送使用帮助:

if((message.MsgType == 'event') && (message.Event == 'subscribe'))  

{  

    ....  

    res.reply(replyStr);  

} 

微信截图如下:

使用Nodejs开发微信公众号后台服务实例

NodeJs 相关文章推荐
NodeJS实现客户端js加密
Jan 09 NodeJs
利用nodejs监控文件变化并使用sftp上传到服务器
Feb 18 NodeJs
angular2+nodejs实现图片上传功能
Mar 27 NodeJs
nodejs批量下载图片的实现方法
May 19 NodeJs
nodejs 图片预览和上传的示例代码
Sep 30 NodeJs
nodejs实现解析xml字符串为对象的方法示例
Mar 14 NodeJs
nodejs 简单实现动态html的方法
May 12 NodeJs
详解Nodejs内存治理
May 13 NodeJs
nodejs用gulp管理前端文件方法
Jun 24 NodeJs
基于Koa(nodejs框架)对json文件进行增删改查的示例代码
Feb 02 NodeJs
nodejs如何在package.json中设置多条启动命令
Mar 16 NodeJs
Nodejs环境实现socket通信过程解析
Jul 03 NodeJs
Nodejs+express+html5 实现拖拽上传
Aug 08 #NodeJs
如何正确使用Nodejs 的 c++ module 链接到 OpenSSL
Aug 03 #NodeJs
NodeJS学习笔记之网络编程
Aug 03 #NodeJs
基于 Docker 开发 NodeJS 应用
Jul 30 #NodeJs
Google官方支持的NodeJS访问API,提供后台登录授权
Jul 29 #NodeJs
使用nodejs、Python写的一个简易HTTP静态文件服务器
Jul 18 #NodeJs
抛弃Nginx使用nodejs做反向代理服务器
Jul 17 #NodeJs
You might like
晋城吧对DiscuzX进行的前端优化要点
2010/09/05 PHP
PHP 如何利用phpexcel导入数据库
2013/08/24 PHP
PHP 使用pcntl和libevent 实现Timer功能
2013/10/27 PHP
使用phpQuery获取数组的实例
2017/03/13 PHP
解析javascript 浏览器关闭事件
2013/07/08 Javascript
js实现touch移动触屏滑动事件
2015/04/17 Javascript
js实现获取div坐标的方法
2015/11/16 Javascript
AngularJS实现Model缓存的方式
2016/02/03 Javascript
javascript点击按钮实现隐藏显示切换效果
2016/02/03 Javascript
jquery表单验证插件formValidator使用方法
2016/04/01 Javascript
javascript实现延时显示提示框特效代码
2016/04/27 Javascript
jQuery层次选择器用法示例
2016/09/09 Javascript
jQuery图片前后对比插件beforeAfter用法示例【附demo源码下载】
2016/09/20 Javascript
jQuery 选择器(61种)整理总结
2016/09/26 Javascript
jQuery根据ID、CLASS、等获取对象的实例
2016/12/04 Javascript
关于vue.js v-bind 的一些理解和思考
2017/06/06 Javascript
JS将网址url转化为JSON格式的方法
2018/07/02 Javascript
vue 监听某个div垂直滚动条下拉到底部的方法
2018/09/15 Javascript
解决layui-table单元格设置为百分比在ie8下不能自适应的问题
2019/09/28 Javascript
vue+elementui通用弹窗的实现(新增+编辑)
2021/01/07 Vue.js
[01:32]完美世界DOTA2联赛10月29日精彩集锦
2020/10/30 DOTA
python list 合并连接字符串的方法
2013/03/09 Python
Python中字典(dict)和列表(list)的排序方法实例
2014/06/16 Python
python3使用urllib模块制作网络爬虫
2016/04/08 Python
python多进程实现进程间通信实例
2017/11/24 Python
python 按不同维度求和,最值,均值的实例
2018/06/28 Python
Django框架会话技术实例分析【Cookie与Session】
2019/05/24 Python
使用python将mysql数据库的数据转换为json数据的方法
2019/07/01 Python
使用python3批量下载rbsp数据的示例代码
2019/12/20 Python
Keras在训练期间可视化训练误差和测试误差实例
2020/06/16 Python
应用数学自荐书范文
2013/11/24 职场文书
车间操作工岗位职责
2013/12/19 职场文书
2014党员民主评议个人总结
2014/09/10 职场文书
运动会搞笑广播稿
2014/10/14 职场文书
民事和解协议书格式
2014/11/29 职场文书
餐馆开业致辞
2015/08/01 职场文书