使用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实用示例 缩址还原
Dec 28 NodeJs
将nodejs打包工具整合到鼠标右键的方法
May 11 NodeJs
使用nodejs、Python写的一个简易HTTP静态文件服务器
Jul 18 NodeJs
Nodejs学习笔记之Stream模块
Jan 13 NodeJs
nodejs导出excel的方法
Jun 30 NodeJs
iPhone手机上搭建nodejs服务器步骤方法
Jul 06 NodeJs
NodeJS与HTML5相结合实现拖拽多个文件上传到服务器的实现方法
Jul 26 NodeJs
NodeJS链接MySql数据库的操作方法
Jun 27 NodeJs
NodeJS收发GET和POST请求的示例代码
Aug 25 NodeJs
nodejs连接mysql数据库及基本知识点详解
Mar 20 NodeJs
nodejs搭建本地服务器轻松解决跨域问题
Mar 21 NodeJs
对mac下nodejs 更新到最新版本的最新方法(推荐)
May 17 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
php实现监控varnish缓存服务器的状态
2014/12/30 PHP
详解YII关联查询
2016/01/10 PHP
Yii框架弹出窗口组件CJuiDialog用法分析
2017/01/07 PHP
js每次Title显示不同的名言
2008/09/25 Javascript
javascript document.execCommand() 常用解析
2009/12/14 Javascript
Jquery 获取指定标签的对象及属性的设置与移除
2014/05/29 Javascript
[原创]Javascript 实现广告后加载 可加载百度谷歌联盟广告
2016/05/11 Javascript
AngularJS基础 ng-keypress 指令简单示例
2016/08/02 Javascript
详解Bootstrap的iCheck插件checkbox和radio
2016/08/24 Javascript
详解ECharts使用心得总结
2016/12/06 Javascript
详解vue项目构建与实战
2017/06/27 Javascript
Angular4学习笔记之根模块与Ng模块
2017/09/09 Javascript
原生JavaScript实现的简单放大镜效果示例
2018/02/07 Javascript
Vue 获取数组键名的方法
2018/06/21 Javascript
vue生命周期和react生命周期对比【推荐】
2018/09/19 Javascript
详解mpvue开发微信小程序基础知识
2019/09/23 Javascript
详解elementUI中input框无法输入的问题
2020/04/27 Javascript
2020京东618叠蛋糕js脚本(亲测好用)
2020/06/02 Javascript
vue打包通过image-webpack-loader插件对图片压缩优化操作
2020/11/12 Javascript
django.db.utils.ProgrammingError: (1146, u“Table‘’ doesn’t exist”)问题的解决
2018/07/13 Python
pytorch 共享参数的示例
2019/08/17 Python
详解python中eval函数的作用
2019/10/22 Python
Django 自定义404 500等错误页面的实现
2020/03/08 Python
django 链接多个数据库 并使用原生sql实现
2020/03/28 Python
Django后端分离 使用element-ui文件上传方式
2020/07/12 Python
Python函数__new__及__init__作用及区别解析
2020/08/31 Python
Pyecharts 中Geo函数常用参数的用法说明
2021/02/01 Python
详解css3 Transition属性(平滑过渡菜单栏案例)
2017/09/05 HTML / CSS
详解canvas多边形(蜘蛛图)的画法示例
2018/01/29 HTML / CSS
给领导的致歉信范文
2014/01/13 职场文书
送达通知书
2015/04/25 职场文书
政审证明材料
2015/06/19 职场文书
公司车辆管理制度
2015/08/04 职场文书
小学四年级班主任工作经验交流材料
2015/11/02 职场文书
2016年国庆节假期旅游工作总结
2016/04/01 职场文书
Linux、ubuntu系统下查看显卡型号、显卡信息详解
2022/04/07 Servers