• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >JavaScript > 详解nodejs微信公众号开发——1.接入微信公众号

详解nodejs微信公众号开发——1.接入微信公众号

作者:芒果屋里的猫 字体:[增加 减小] 来源:互联网 时间:2017-05-11

芒果屋里的猫通过本文主要向大家介绍了nodejs开发微信公众号,nodejs微信公众号,nodejs开发实战详解,微信公众号详解,nodejs 微信开发等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

接入微信公众号是开发的第一步,万事开头难,走好第一步,后面的路就更宽广。

1.公众平台测试帐号的使用

登录微信公众平台,由于很多开发人员并没有认证的的微信公众号,所以比较折中的方式是使用公众平台测试帐号来测试功能,其优势是能够测试微信公众号的绝大部分功能,不受认证门槛的限制。

进入测试账号管理界面:

我们需要配置接口的信息,URL和Token是微信公众平台和本地开发服务建立连接的桥梁。

微信配置好后,扫面下方的测试号二维码,即可以在手机上测试开发的功能。

2.验证公众号

一图胜千言。接入公众号时,微信公众平台需要验证开发者的身份,向开发者填写的URL发送一个GET请求,请求中包含4个参数:signature、echostr、timestamp和nonce,收到该请求,我们需要做的事情:

  1. 将token、timestamp和nonce三个参数进行字典排序;
  2. 将三个字符串拼接成一个字符串进行sha1加密;
  3. 将加密后的字符串与signature进行比较,如果相同,表示这个请求来自微信,我们直接原样返回echostr的内容,接入验证成功。

3.搭建开发服务器

搭建开发服务器的方式有很多,如购买云服务器、使用花生壳、ngrok、localtunnel等。这里为了简单起见采用localtunnel。先全局方式安装localtunnel,

npm install -g lt
</div>

启动lt

lt --port 8080  //对外暴露8080端口,可端口号可自己随便设定
</div>

4.编写代码

好了,现在开始编写app.js的代码:

'use strict'

var Koa = require('koa');
var sha1 = require('sha1');

var config = {
  wechat:{
    appID:'...', //填写你自己的appID
    appSecret:'...', //填写你自己的appSecret
    token:'...' //填写你自己的token
  }
};

var app = new Koa();

app.use(function *(next){
  var token = config.wechat.token;
  var signature = this.query.signature;
  var nonce = this.query.nonce;
  var timestamp = this.query.timestamp;
  var echostr = this.query.echostr;
  var str = [token,timestamp,nonce].sort().join(''); //按字典排序,拼接字符串
  var sha = sha1(str); //加密
  this.body = (sha === signature)? echostr + '' : 'failed'; //比较并返回结果
});
app.listen(8080);

</div>

5.配置测试公众号信息

代码编写完毕,现在开始正式配置啦。在终端中输入lt --port 8080启动localtunnel,得到对外可访问的URL:

这个URL填写到测试账号管理界面中的URL,Token字段可随意填写,方便起见,就用wemovie吧!

填写完毕,点击提交,发现验证成功,恭喜!

注:

  1. 由于localtunnel不是很稳定,所以可能一开始点击提交提示的是黄条的配置失败,需要多点一两次按钮;
  2. 每次重启程序,都需要重启localtunnel获取新的URL,然后重新配置。(这就是选择简单付出的代价T_T)

到此为止,已经打开了通向微信公众号开发的大门,接下来,我们将继续探索nodejs微信公众号开发之旅。以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 详解nodejs微信公众号开发——6.自定义菜单
  • 详解nodejs微信公众号开发——5.素材管理接口
  • 详解nodejs微信公众号开发——4.自动回复各种消息
  • 详解nodejs微信公众号开发——3.封装消息响应模块
  • 详解nodejs微信公众号开发——2.自动回复
  • 详解nodejs微信公众号开发——1.接入微信公众号

相关文章

  • 2017-05-11jQuery弹出窗口简单实现代码
  • 2017-05-11vue2笔记 — vue-router路由懒加载的实现
  • 2017-05-11js仿百度音乐全选操作
  • 2017-05-11利用Node.js对文件进行重命名
  • 2017-05-11关于jQuery中fade(),show()起始位置的一点小发现
  • 2017-05-11vue2 前后端分离项目ajax跨域session问题解决方法
  • 2017-05-11BootStrap栅格系统、表单样式与按钮样式源码解析
  • 2017-05-11JS和canvas实现俄罗斯方块
  • 2017-05-11JavaScript验证知识整理
  • 2017-05-11使用bootstrap-paginator.js 分页来进行ajax 异步分页请求示例

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • ES6之字符串的扩展
    • 微信小程序 picker-view 组件详解及简单实例
    • Node.js 中exports 和 module.exports 的区别
    • JavaScript在form表单中使用button按钮实现submit提交方法
    • bootstrap weebox 支持ajax的模态弹出框
    • 使用Xcache缓存器加速PHP网站的配置方法
    • nodejs进阶(6)—连接MySQL数据库示例
    • jquery做个日期选择适用于手机端示例
    • JS获取多维数组中相同键的值实现方法示例
    • js仿搜狐视频记录片列表展示效果

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有