使用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打包工具整合到鼠标右键的方法
May 11 NodeJs
使用nodejs、Python写的一个简易HTTP静态文件服务器
Jul 18 NodeJs
解决nodejs中使用http请求返回值为html时乱码的问题
Feb 18 NodeJs
nodejs开发——express路由与中间件
Mar 24 NodeJs
nodejs基于express实现文件上传的方法
Mar 19 NodeJs
nodeJS模块简单用法示例
Apr 21 NodeJs
通过nodejs 服务器读取HTML文件渲染到页面的方法
May 17 NodeJs
Nodejs让异步变成同步的方法
Mar 02 NodeJs
Nodejs异步流程框架async的方法
Jun 07 NodeJs
NodeJs实现简易WEB上传下载服务器
Aug 10 NodeJs
nodejs nedb 封装库与使用方法示例
Feb 06 NodeJs
NodeJS配置CORS实现过程详解
Dec 02 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
一个从别的网站抓取信息的例子(域名查询)
2006/10/09 PHP
网站防止被刷票的一些思路与方法
2015/01/08 PHP
php中json_encode不兼容JSON_UNESCAPED_UNICODE的解决方案
2016/05/31 PHP
PHPExcel实现表格导出功能示例【带有多个工作sheet】
2018/06/13 PHP
jQuery 全选/反选以及单击行改变背景色实例
2013/07/02 Javascript
node.js中的buffer.copy方法使用说明
2014/12/14 Javascript
jquery trigger实现联动的方法
2016/02/29 Javascript
js中DOM三级列表(代码分享)
2017/03/20 Javascript
ES6新特性五:Set与Map的数据结构实例分析
2017/04/21 Javascript
详解Vue用axios发送post请求自动set cookie
2017/05/10 Javascript
Node.js中你不可不精的Stream(流)
2018/06/08 Javascript
详解在create-react-app使用less与antd按需加载
2018/12/06 Javascript
vue实现验证用户名是否可用
2021/01/20 Vue.js
python利用datetime模块计算时间差
2015/08/04 Python
python3使用urllib模块制作网络爬虫
2016/04/08 Python
Python实现新浪博客备份的方法
2016/04/27 Python
Python常见加密模块用法分析【MD5,sha,crypt模块】
2017/05/24 Python
python实现员工管理系统
2018/01/11 Python
python使用sqlite3时游标使用方法
2018/03/13 Python
Python实现微信小程序支付功能
2019/07/25 Python
Pytorch反向求导更新网络参数的方法
2019/08/17 Python
Django模板语言 Tags使用详解
2019/09/09 Python
python2和python3应该学哪个(python3.6与python3.7的选择)
2019/10/01 Python
Python-jenkins模块之folder相关操作介绍
2020/05/12 Python
简单了解python列表和元组的区别
2020/05/14 Python
python 代码实现k-means聚类分析的思路(不使用现成聚类库)
2020/06/01 Python
什么是Python变量作用域
2020/06/03 Python
解决pyinstaller 打包exe文件太大,用pipenv 缩小exe的问题
2020/07/13 Python
Python如何重新加载模块
2020/07/29 Python
CSS3自定义滚动条样式的示例代码
2017/08/21 HTML / CSS
大专生简历的自我评价
2013/11/26 职场文书
大学辅导员述职报告
2015/01/10 职场文书
爸爸的三轮车观后感
2015/06/16 职场文书
校运会广播稿
2015/08/19 职场文书
教师正风肃纪心得体会
2016/01/15 职场文书
导游词之日月潭
2019/11/05 职场文书