Skip to content

商务合作:vTikTok


公众号:



微信公众号开发


官方开发文档

公众号的开发说难也不难,说简单也不简单,但总体开发成本:公众号 < 小程序 < App,属于相对最容易也最快获得回报的开发方式了。

这里介绍一种最快的方式,基于现有的框架快速实现公众号后台开发,当然前提是你已经有了Python,Linux,Docker等基本功。

大致步骤

  1. 部署基于WeRobot的后端程序
  2. 公众号后台配置URL,Token等验证信息

公众平台基本配置

所以流程并不复杂,注意上述的顺序,一定要先部署,再配置公众号,因为公众号后台要验证Token信息(自定义的,和你的服务器一致即可)

测试微信API的时候,由于验证都是在云端的,这非常不方便,有两种方式可以解决:

  1. Frp内网穿透
  2. 宝塔面板部署,对于小白这个会更方便一些
  3. Docker部署

作者本人是用Docker Compose编排部署的,同样比较快捷方便,不过不断上传重启容器也非常耗时,可以利用vscode的远程连接直接在云端编写代码并重启容器。

如何重启Docker Compose中的某一个容器呢?

执行docker-compose restart <service-name> 命令

sh
sudo docker compose restart werobot
sudo docker compose restart werobot

基于WeRoBot开发微信后端

pip install werobot

建立一个main.py

py
import werobot

robot = werobot.WeRoBot(token='alien_wx_token')

@robot.text
def hello_world():
    return 'Hello World!'

if __name__ == '__main__':
    robot.run(host="0.0.0.0", port=8080)
import werobot

robot = werobot.WeRoBot(token='alien_wx_token')

@robot.text
def hello_world():
    return 'Hello World!'

if __name__ == '__main__':
    robot.run(host="0.0.0.0", port=8080)

大功告成,一个最简单的微信公众号后台开发就完成了。

Alt text

当用户给你的公众号发送任何消息的时候,你的公众号都会发送Hello World文案。

Alt text

当然了,如果你的公众号只能回复Hello World,那肯定会被粉丝骂"神经病啊",对不对,我们真正想要的是一个具有交互能力的,甚至是文字版的App,基于微信生态强大的API,实现这些并不是问题。

不过在开发过程中,直接在线上环境调试是不太好的,因为一些调试上的BUG很容易被微信误以为是攻击,倒霉一点就会被限制接口调用。

笔者本人在使用某位朋友的支付宝支付调试的时候,因为线上频繁调试BUG,就不幸让其支付宝商户平台停止运营了3天才恢复!

所以,一定要使用公众平台测试账号配合微信开发者工具来开发公众号相关的功能。

开发者工具

Alt text

微信给我们提供了现有的测试账号,且测试账号是拥有公众号开发的所有权限的,用它!

Alt text

测试账号的权限非常多,因为个人的【订阅号】权限相对较少,面对企业的【服务号】权限与沙箱差不多是一致的。

进入沙盒调试

Alt text

重点关注图中重要的信息,URL填写你的服务器地址,Token填写你的服务器设置的Token,这个值在两端保存一致即可。

继续编写服务端代码

创建菜单

python
client = robot.client
client.create_menu({
    "button": [
        {
            "type": "click",
            "name": "今日推荐",
            "key": "KEY_TODAY_RECOMMEND"
        },
        {
            "type": "click",
            "name": "作者简介",
            "key": "KEY_ABOUT_ME"
        },
        {
            "name": "菜单",
            "sub_button": [
                {
                    "type": "view",
                    "name": "搜索",
                    "url": "http://www.soso.com/"
                },
                {
                    "type": "view",
                    "name": "视频",
                    "url": "http://v.qq.com/"
                },
                {
                    "type": "click",
                    "name": "赞一下我们",
                    "key": "KEY_GOOD"
                }
            ]
        }
    ]
})
client = robot.client
client.create_menu({
    "button": [
        {
            "type": "click",
            "name": "今日推荐",
            "key": "KEY_TODAY_RECOMMEND"
        },
        {
            "type": "click",
            "name": "作者简介",
            "key": "KEY_ABOUT_ME"
        },
        {
            "name": "菜单",
            "sub_button": [
                {
                    "type": "view",
                    "name": "搜索",
                    "url": "http://www.soso.com/"
                },
                {
                    "type": "view",
                    "name": "视频",
                    "url": "http://v.qq.com/"
                },
                {
                    "type": "click",
                    "name": "赞一下我们",
                    "key": "KEY_GOOD"
                }
            ]
        }
    ]
})

设置菜单的点击事件:

python
@robot.key_click("KEY_TODAY_RECOMMEND")
def rec(message):
    return '你点击了“今日推荐”按钮'
@robot.key_click("KEY_TODAY_RECOMMEND")
def rec(message):
    return '你点击了“今日推荐”按钮'

Alt text

注意:个人账号没有自定义菜单权限,需要使用测试号或者企业号,否则报错:48001: api unauthorized rid

根据用户输入回复对应内容

python
@robot.filter("讲一个笑话")
def joke(message):
    # reply = TextReply(message=message, content="笑不活了")
    # data = ApiUtils.joke_data()
    return "让我给你讲一个笑话,这简直就是一个天大的笑话!"
@robot.filter("讲一个笑话")
def joke(message):
    # reply = TextReply(message=message, content="笑不活了")
    # data = ApiUtils.joke_data()
    return "让我给你讲一个笑话,这简直就是一个天大的笑话!"

发送图文链接

python
@robot.filter("2")
def blog(message):
    reply = ArticlesReply(message=message)
    article = Article(
            title="我的博客", 
            description="我的个人博客",
            img="https://12345.com/0.png",
            url="https://www.12345.com/u/79a88a044955"
    )
    reply.add_article(article)
    return reply
@robot.filter("2")
def blog(message):
    reply = ArticlesReply(message=message)
    article = Article(
            title="我的博客", 
            description="我的个人博客",
            img="https://12345.com/0.png",
            url="https://www.12345.com/u/79a88a044955"
    )
    reply.add_article(article)
    return reply

发送图片

python
@robot.filter("3")
def send_image(message):
    media_id = "这里是你上传图片到微信后台生成的media_id"
    # 返回图片
    if media_id:
        reply = ImageReply(message=message, media_id=media_id)
        return reply
    else:
        return "图片不存在!"
@robot.filter("3")
def send_image(message):
    media_id = "这里是你上传图片到微信后台生成的media_id"
    # 返回图片
    if media_id:
        reply = ImageReply(message=message, media_id=media_id)
        return reply
    else:
        return "图片不存在!"

上传临时图片

res = client.upload_media("image", open("qrcode.jpg", "rb"))

上传永久多媒体文件。

media_json = client.upload_permanent_media("image", open("qrcode.jpg", "rb"))

被关注时候回复用户消息

python
# 被关注
@robot.subscribe
def subscribe(message):
    return "谢谢您的关注!"
# 被关注
@robot.subscribe
def subscribe(message):
    return "谢谢您的关注!"

处理默认消息

如果上面没有可以处理的消息,那么最底部的handler将被触发:

python
@robot.text
def handle_other(message):
    if message.content == "消息1":
        return f'执行:{message.content}'
    if message.content == "消息2":
        return f'执行:{message.content}'
    else:
        return "谢谢你的关注!"
@robot.text
def handle_other(message):
    if message.content == "消息1":
        return f'执行:{message.content}'
    if message.content == "消息2":
        return f'执行:{message.content}'
    else:
        return "谢谢你的关注!"

主要的就是这些了,当然还有一些API,比如授权,支付等等,这些功能用小程序实现会更好,有时间再写小程序相关的开发。实在太忙了,公众号以及其他平台都断更将近一年,谢谢你们的支持!