使用NodeJs开发微信公众号(一)

  准备工作

1.首先注册自己的微信公众号。

微信公众号现在分为订阅号,服务号,企业号,服务号和企业号不对个人开发者开放,所以我们只能选择订阅号。

但是订阅号也有认证和未认证之分,认证的订阅号支持的接口更多也更高级,下图是微信的接口权限图,只截取了一部分。

 

如果我们想测试这些接口怎么办?我们可以申请微信的测试账号,测试账号只能用于测试接口,不能用于真实的项目。下面就看看怎么申请测试账号吧。

1.1进入微信公众平台首页 https://mp.weixin.qq.com/

1.2在下方的账号分类里找到订阅号,点击开发文档,在左侧边栏找到开始开发-接口测试号申请,如下图所示

点击进入申请就好了。

2.一个域名和一个服务器,强烈建议在阿里云上购买,便宜稳定省心。现在.cn的域名29元/年,1核1G的服务器是330元/年。具体怎么申请,以及服务器怎么使用,大家可以网上自行百度,这里就不再赘述了。

准备工作就到这里,下面正式开始微信公众号的开发。

二、接入微信

第一步、填写服务器配置信息 

进入微信测试号管理页面,填写接口配置信息。

 

1.URL地址,必须以http://或https://开始,分别支持80和443端口,例如:http://www.baidu.com/,这里你应该填写你自己的域名,这个域名指向的是你买的服务器。

2.Token是必须为英文或者数字,长度为2-32个字符。

第二步、验证消息的确来自微信服务器

为了验证消息的确来自微信服务器,微信服务器会向我们的服务器发送GET请求,GET请求携带四个参数

1)signature:微信加密签名,签名里包含了我们填写的Token信息,和请求中的timestamp和nonce参数

2)timestamp:时间戳

3)nonce:随机数

4)echostr:随机字符串

开发者通过校验signature对请求进行验证,下面介绍校验算法。

1)将Token,timestamp,nonce按字典排序,好在js的sort()方法可以帮我们完成这个工作

2)排序之后,将这三个参数拼成一个字符串,进行sha1加密,这里也不用害怕,npm的有现成的sha1包。

3)然后判断signature与我们自己用sha1加密后的字符串是否相等,如果相等则说明请求来自于微信,然后我们将echostr原封不动的返回给微信服务器,接入验证就成功了。

好了,有了这些理论知识,我们就开始编写代码吧。

  编写接入微信服务器代码

新建index.js,并在当当前目录下安装koa框架和sha1模块.  

首先我们要安装koa框架,Koa是继Express之后的一个新的Web框架,使用Koa框架可以是Web开发,变得更加容易和快速,因为这里只用到koa一些简单的功能,所以不做详细的介绍了。  

 安装sha1模块,用于进行将字符串进行sha1加密。

npm install koa

npm install sha1

下面是index.js中的代码

//严格模式
"use strict"

//引入koa框架
let Koa=require("koa");
//引入sha1模块
let sha1=require("sha1");

let koa=new Koa();

//微信订阅号的配置信息
let config={
    wechat:{
        appID:"wx2ea795e409b2c674",
        appsecret:"e4632492abb3de0943fc7ca20c4b27d0",
//这里你得填写你自己设置的Token值 token:
"wechat", } }; koa.use(function(ctx){ //ctx.query获取请求中携带的参数 let token=config.wechat,token; //获取请求中的signature let signature=ctx.query.signature; //获取请求中的timestamp let timestamp=ctx.query.timestamp; //获取请求中的nonce let nonce=ctx.query.nonce; //获取请求中的echostr let echostr=ctx.query.echostr; //将Token,timestamp,nonce按字典排序,排序后链接成一个字符串 let str=[token,timestamp,nonce].sort().join(""); //使用sha1模块进行sha1加密 let sha1Str=sha1(str); //判断加密后的字符串与请求中signature是否相等 //如果相等返回echostr if(sha1Str === signature){ //将echostr返回给微信服务器 ctx.body=echostr; } else{ ctx.body="wrong"; } }) //监听服务器的80端口,这里需要注意一下,如果你监听的不是80端口,那么你就得修改url,在url最后加上你要监听的端口号,例如http://www.baidu.com:3000 koa.listen(80); console.log("服务器已经跑起来了.....");

 

接入服务器的代码就这么多,最后文件的结构是这样的

node_modules这个文件夹里存放的就是koa和sha1相关的文件。然后将这个文件夹挪到你的服务器上,

并在这个目录下,用node把Index.js跑起来,成功的话,应该是下面的效果。

最后就可以提交我们的信息了,其实在提交之后,微信服务器会向我们的服务器发送请求,我们的代码就是处理这个请求,并把微信服务器需要的信息响应给它。

提交之后,就会显示配置成功。

以后我们就可以使用我们自己的服务器,向微信服务器发送请求了。

下一期将会讲解怎么获取access_token,并缓存access_token。

这一期的代码我已经提交到我的github上了,有兴趣的大家可以来看看使用Node开发微信订阅号

posted @ 2017-07-23 13:49  我的bug我做主  阅读(2295)  评论(0编辑  收藏  举报