【微信公众号开发系列文章】一、微信公众号开发环境搭建

写在最前方!

作为开发者,在学习任何技术之前一定要先看官方文档。

官方文档:https://developers.weixin.qq.com/doc/offiaccount/Getting_Started/Overview.html

微信公众号有订阅号、服务号、企业微信号三类,可根据自己实际应用场景注册对应的类型即可,在开发中我们可以使用微信公众平台测试号进行开发测试。

但是,在开发之前一定要确定项目实际所运行的账号类型,因为这牵扯到官方的接口权限问题。针对不同的权限,在开发之前我们需要根据业务场景及接口权限设计好对应场景实现的解决方案。

一、开发准备工作介绍:

我们需要准备一个微信公众平台测试账号,微信公众平台测试账号不需要注册,任何人可以通过个人微信扫描二维码登录即可获得一个测试账号。

测试账号登录网址:
https://mp.weixin.qq.com/debug/cgi-bin/sandbox?t=sandbox/login

还需要准备一个内网穿透工具(ngrok),开发过程中我们需要将本地开发服务器映射到外网,模拟真实服务器使用,在这里我们可以使用(Express)配合(MongoDB)数据库搭建一个简单的Web 服务器应用程序。

二、公众号用户消息处理流程图片微信公众号消息处理流程示意图

如图所示:用户通过微信公众号无论是发送了一段文字、一张图片又或者是点击了某一个按钮,用户所有这些操作,首先会被发送至微信服务器,然后经由微信服务器将消息处理之后,按照一定格式发送至开发者服务器。开发服务器在接收到微信服务器发送的消息后,可依据接口文档针对用户操作处理对应的业务逻辑,然后将结果按照一定的格式返回给微信服务器,再由微信服务器将数据处理之后返回给用户。

对于开发者服务器来说,微信服务器与用户之间的交互不需要关注,开发者服务器只需要关注微信服务器发送给开发者服务器的数据,然后依据文档对接收到的数据进行处理。所以开发者服务器在接收到每一个请求时都必须验证一下该消息来源是否由微信服务器发出,验证通过之后才能依据接口文档进行对应的业务逻辑处理。

三、微信公众平台测试号说明

图片

1、测试账号信息:

开发者ID(AppID):开发者ID是公众号开发识别码,配合开发者秘钥可调用公众号的接口能力。

开发者秘钥(AppSecret):开发者秘钥是校验公众号开发者身份的密码,具有极高的安全性。切记勿把秘钥直接交给第三方开发者或直接存储在代码中。如需第三方代为开发公众号功能,请使用授权方式接入。

2、接口配置信息:

URL:开发者服务器地址,该URL是开发者服务器用来接收和响应微信服务器消息和事件的接口。

Token:随机字符串,用作生成签名(必须为英文或数字,长度为3-32字符)该签名在后边会用到,这里暂时随便填个内容也可以。

3、JS接口安全域名:

设置JS接口安全域名后,公众号开发者可在该域名下调用微信开放的JS接口。

以上内容可通过官方文档:开发前必读及开始开发—接入指南深入理解。

四、搭建本地应用

采用Express+MongoDB技术栈搭建一个简单的本地开发者服务器。

1、配置信息

在这里插入图片描述

2、最简单服务器代码示例:
const express = require('express')
const app = express()
const port = 3000

// 定义微信服务器接口获取微信服务器携带过来的参数。
app.get("/wechat", (req, res) => {
  console.log(req.query);
  res.send("Hello World!");
});

app.listen(port, () => {
  console.log(`Example app listening at http://localhost:${port}`)
})
3、req.query返回信息

在这里插入图片描述

4、req.query返回信息字段说明

在这里插入图片描述

开发者通过signature对请求进行校验。若确认此次GET请求来自微信服务器,原样返回echostr参数内容,则开发者服务器配置成功,否则开发者服务器配置失败。

加密/校验流程如下:

  1. 将token、timestamp、nonce三个参数进行字典序排序;
  2. 将三个参数字符串拼接成一个字符串进行sha1加密 ;
  3. 开发者获得加密后的字符串可与signature对比,如果字符串相等,则表示该请求来源于微信。
5、js代码示例:
app.get("/wechat", (req, res) => {
  const { signature, echostr, timestamp, nonce } = req.query;
  const token = "lizhijie0429";
  const str = [token, timestamp, nonce].sort().join("");
  const sha1Str = sha1(str);
  sha1Str === signature ? res.send(echostr) : res.send("error");
});

至此,再去提交接口配置信息,若提示成功,则表示我们开发环境搭建完成。

往期内容:

【Vue】在Vite+Vue3.0中使用jsx语法开发。

【Vite+vue3】vue3当中keep-alive的使用

图片

  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

qq_16221009

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值