Python FastAPI 微信公众号后台服务器验证


微信公众平台开发接入概述

接入微信公众平台开发,开发者需要按照如下步骤完成:
1、填写服务器配置
2、验证服务器地址的有效性
3、依据接口文档实现业务逻辑

一、填写服务器配置

填写服务器地址(URL)、Token和EncodingAESKey,

  1. URL是开发者用来接收微信消息和事件的接口URL。
  2. Token可由开发者可以任意填写,用作生成签名(该Token会和接口URL中包含的Token进行比对,从而验证安全性)。
  3. EncodingAESKey由开发者手动填写或随机生成,将用作消息体加解密密钥。
    在这里插入图片描述

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

开发者提交信息后,微信服务器将发送GET请求到填写的服务器地址URL上,GET请求携带参数如下表所示:

参数描述
signature微信加密签名,signature结合了开发者填写的token参数和请求中的timestamp参数、nonce参数。
timestamp时间戳
nonce随机数
echostr随机字符串

开发者通过检验signature对请求进行校验(下面有校验方式)。若确认此次GET请求来自微信服务器,请原样返回echostr参数内容,则接入生效,成为开发者成功,否则接入失败。
加密/校验流程如下:

  1. 将token、timestamp、nonce三个参数进行字典序排序
  2. 将三个参数字符串拼接成一个字符串进行sha1加密
  3. 开发者获得加密后的字符串可与signature对比,标识该请求来源于微信

注:返回值需要是HTMLResponse,刚开始直接返回echostr一直返回token验证失败

FastAPI实现消息认证

# conding=gbk
from fastapi import APIRouter, Depends
from fastapi.responses import HTMLResponse
from starlette.requests import Request
from app.utils.responses import ResponsesExampleVale
from extensions.logger import logger
import hashlib
router = APIRouter()
WINXIN_TOKEN = "你的token"


@router.get(
    "/verify/",
    tags=["验证服务器地址的有效性"],
    responses=ResponsesExampleVale(
        "随机字符串"
    )
)
async def check_signature(
        request: Request,
        signature: str,
        timestamp: str,
        nonce: str,
        echostr: str,
):
    """
    signature 微信加密签名,signature结合了开发者填写的token参数和请求中的timestamp参数、nonce参数。
    timestamp 时间戳
    nonce 随机数
    echostr 随机字符串

    开发者通过检验signature对请求进行校验(下面有校验方式)。
    若确认此次GET请求来自微信服务器,请原样返回echostr参数内容,则接入生效,成为开发者成功,否则接入失败。
    加密/校验流程如下:
        1)将token、timestamp、nonce三个参数进行字典序排序
        2)将三个参数字符串拼接成一个字符串进行sha1加密
        3)开发者获得加密后的字符串可与signature对比,标识该请求来源于微信
    """
    logger.info(f"signature: {signature}")
    logger.info(f"timestamp: {timestamp}")
    logger.info(f"nonce: {nonce}")
    logger.info(f"echostr: {echostr}")

    _ = "".join(sorted([WINXIN_TOKEN, timestamp, nonce]))
    sign = hashlib.sha1(_.encode('UTF-8')).hexdigest()
    return HTMLResponse(content=echostr if sign == signature else "error")

三、依据接口文档实现业务逻辑

前提条件:
在这里插入图片描述
获取AppSecret 需要 注册微信扫码,然后输入公众号登录密码。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

不太灵光的程序员

有用的话可以请博主喝杯咖啡续命

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

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

打赏作者

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

抵扣说明:

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

余额充值