• 2023 年最新腾讯官方 QQ 机器人(QQ 群机器人 / QQ 频道机器人)超详细开发教程


    注册 QQ 开放平台账号

    QQ 开放平台是腾讯应用综合开放类平台,包含 QQ 机器人、QQ 小程序、QQ 小游戏 等集成化管理,也就是说你注册了QQ 开放平台,你开发 QQ 机器人还是 QQ 小程序都是在这个平台进行部署上线和管理。

    在这里插入图片描述
    如何注册 QQ 开放平台账号?点击首页右上角【立即注册】

    注意主体的选择,当然无论是企业还是个人,都是可以开发 QQ 小程序 或者 QQ 机器人 的,但是如果您是个人主体的话,那么你的权限将有所局限,因为部分服务权限是需要企业主体的。

    企业主体入驻开发者默认支持频道、群场景开发能力;个人主体入驻开发者默认仅支持频道场景开发能力。除默认开通的能力外,后续其他接口能力申请上,企业开发者与个人开发者也存在差异。

    在这里插入图片描述

    温馨提示:姓名和身份证号码务必与手机号码对应运营商实名登记的信息一致,否则会提示错误。

    创建 QQ 机器人

    注册完成后登陆开放平台!在机器人分栏点击【创建机器人】
    在这里插入图片描述
    填写 QQ 机器人资料信息(名称、头像、介绍)

    在这里插入图片描述
    QQ 机器人管理端后台

    资料提交成功后,即会生成 appid,点击对应的应用即可跳转管理端。

    在这里插入图片描述
    机器人类型 和 测试频道 / 群 配置

    机器人类型 包含 私域机器人或者 公域机器人。当然公域机器人对于服务器的要求过高,我们这边也可以选择私域机器人进行开发。特别注意在选择沙箱测试频道的时候,你必须提前创建个沙箱测试频道,必须<20人的频道。但是选择沙箱测试 QQ 群则需要您是企业资质。

    沙箱频道仅可设置当前用户为频道主/管理员的频道、沙箱群仅可设置当前用户为群主/群管理员的群,且沙箱频道成员、沙箱群成员不可大于20人。

    在这里插入图片描述

    在沙箱配置页面不同类型开发者支持开发不同场景机器人功能

    建议开发者根据实际的需要,选择在不同场景开发机器人,完成对应场景的沙箱环境配置。配置沙箱后,开发者可在「功能配置」、「使用范围与人员」页面解锁相应场景的配置能力。

    认证身份QQ频道QQ群消息列表单聊
    企业开发者申请后可开发
    个人开发者暂不开放暂不开放

    配置沙箱 QQ 群 / 频道,需要先在QQ客户端创建符合沙箱要求的QQ群/QQ频道。在频道场景,机器人仍然保留「公域」/「私域」机器人的区分,设置为公域机器人保存确认后不可切换为私域机器人,但在「使用范围与人员」可设置公域机器人的允许添加范围:“全部用户可添加”/“仅白名单用户可添加”。配置沙箱频道/群后,机器人会出现在沙箱频道/沙箱群的机器人列表当中。

    查看 QQ 机器人设置

    Token 和 AppSecret

    请妥善保管 QQ 机器人令牌 Token(用于以机器人身份调用 openapi) 和 机器人密钥 AppSecret (用于在 oauth 场景进行请求签名的密钥)

    在这里插入图片描述
    消息 URL 配置

    机器人发送的消息中包含的 URL 必须先在这里设置,消息才可以下发生效。域名需经过ICP备案,新备案域名 24 小时后才可以配置,请下载校验文件,并将文件放置在域名根目录下,并确保可访问该文件。

    在这里插入图片描述

    频道用户意见反馈

    为了帮助开发者获取 C 端用户对于机器人的评价与反馈,平台在频道场景为开发者接入了"兔小巢反馈空间",开发者可以通过创建产品反馈空间。

    在这里插入图片描述

    频道用户意见反馈: 点击进入登陆后,根据提示创建产品,将会获得一个兔小巢反馈空间,C 端用户所填写的机器人反馈将同步至此空间,开发者以后可登陆此空间查看用户反馈。

    产品 ID 填写: 需要在此处填写兔小巢反馈空间的产品 ID,C 端用户的机器人反馈才可同步至此处,详细获取路径如开发者端提示:设置 > 产品设置 > 产品 ID。

    QQ 机器人 SDK

    安装 QQ 机器人 Node.Js SDK

    npm i qq-guild-bot
    
    # 或者使用yarn
    yarn add qq-guild-bot
    
    # 国内安装可以使用腾讯源
    npm i qq-guild-bot --registry=https://mirrors.tencent.com/npm/
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    配置 .env:在根目录创建 .env 环境变量配置文件

    appID=102075492
    token=你的token
    AppSecret=你的AppSecret
    
    • 1
    • 2
    • 3

    websocket 监听

    QQ 机器人 创建 WS 实例并监听消息

    import { createWebsocket } from 'qq-guild-bot';
    const ws = createWebsocket(testConfigWs);
    ws.on('READY', data => {
        console.log('[READY] 事件接收 :', data);
    });
    ws.on('ERROR', data => {
        console.log('[ERROR] 事件接收 :', data);
    });
    ws.on('GUILDS', data => {
        console.log('[GUILDS] 事件接收 :', data);
    });
    ws.on('GUILD_MEMBERS', data => {
        console.log('[GUILD_MEMBERS] 事件接收 :', data);
    });
    ws.on('GUILD_MESSAGES', data => {
        console.log('[GUILD_MESSAGES] 事件接收 :', data);
    });
    ws.on('GUILD_MESSAGE_REACTIONS', data => {
        console.log('[GUILD_MESSAGE_REACTIONS] 事件接收 :', data);
    });
    ws.on('DIRECT_MESSAGE', data => {
        console.log('[DIRECT_MESSAGE] 事件接收 :', data);
    });
    ws.on('INTERACTION', data => {
        console.log('[INTERACTION] 事件接收 :', data);
    });
    ws.on('MESSAGE_AUDIT', data => {
        console.log('[MESSAGE_AUDIT] 事件接收 :', data);
    });
    ws.on('FORUMS_EVENT', data => {
        console.log('[FORUMS_EVENT] 事件接收 :', data);
    });
    ws.on('AUDIO_ACTION', data => {
        console.log('[AUDIO_ACTION] 事件接收 :', data);
    });
    ws.on('PUBLIC_GUILD_MESSAGES', data => {
        console.log('[PUBLIC_GUILD_MESSAGES] 事件接收 :', data);
    });
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39

    监听 QQ 群消息

    const { createOpenAPI, createWebsocket } = require('qq-guild-bot');
    const { config } = require("dotenv")
    config()
    
    const testConfig = {
        appID: process.env.appID,
        token: process.env.token,
        shards: [0, 1],
        intents: ['PUBLIC_GUILD_MESSAGES', 'GROUPS'],
        sandbox: false,
    };
    
    const client = createOpenAPI(testConfig);
    const ws = createWebsocket(testConfig);
    
    ws.on('GROUPS', data => {
        console.log('Gourp messgae:', data);
    });
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18

    配置说明

    参数说明类型
    appIDQQ 机器人 ID(QQ 开放平台机器人管理端获得)String
    token机器人身份调用 openapi(QQ 开放平台机器人管理端获得)String
    shards配置 QQ 机器人分布式部署 [集群编号, 集群数量]Array
    intentsQQ 机器人事件类型订阅Array
    sandboxQQ 机器人是否开启沙箱测试Boolean

    intents 可选值举例:[‘GUILDS’, ‘GUILD_MEMBERS’, ‘GUILD_MESSAGES’,‘GUILD_MESSAGE_REACTIONS’,‘DIRECT_MESSAGE’, ‘INTERACTION’,‘MESSAGE_AUDIT’,‘FORUMS_EVENT’,‘AUDIO_ACTION’, ‘PUBLIC_GUILD_MESSAGES’]

    事件类型的订阅,是有权限控制的,除了 GUILDS,PUBLIC_GUILD_MESSAGES,DIRECT_MESSAGE,GUILD_MEMBERS 事件是基础的事件,默认有权限订阅之外,其他的特殊事件,都需要经过申请才能够使用,如果在鉴权的时候传递了无权限的 intents,websocket 会报错,并直接关闭连接。

    特别注意:intents传空数组时,将默认开启全部事件类型的监听。

    群消息 group message

    Gourp messgae: {
      eventType: 'GROUP_AT_MESSAGE_CREATE',
      eventId: 'GROUP_AT_MESSAGE_CREATE:h2wlsxge4luozgoigwumbriafsda7kdjiuwpmwrrlxqkgxwpynhysl6q6ws849',
      msg: {
        author: {
          id: 'E2976D3827112BFBB2ED537533A36DF1',
          member_openid: 'E2976D3827112BFBB2ED537533A36DF1'
        },
        content: ' 测试',
        group_id: 'A85B11B27A39FB0C238B0F19FA09DDF7',
        group_openid: 'A85B11B27A39FB0C238B0F19FA09DDF7',
        id: 'ROBOT1.0_h2WlSxGE4lUOz.gOiGwumPXNIo3bQDNfDUL9B6RR64rOz1lFtaet2maxZIYEGiAlunES0n.7u0HtihQXiTG9mw!!',
        timestamp: '2023-11-11T23:32:29+08:00'
      }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15

    获取接口凭证

    截止当前日期 2023 年 11 月 10 日,腾讯 BOT 机器人官方还没更新相关 SDK,所以需要进行调用群 API 则需要 POST 请求进行处理,我们通过 axios 库获取接口凭证。

    安装 axios 第三方库

    npm install axios
    
    • 1

    接口凭证 请求参数设置

    clientSecret / AppSecret:oauth 场景进行请求签名的密钥(QQ 开放平台机器人管理端获得)String
    在这里插入图片描述

    接口凭证请求地址:https://bots.qq.com/app/getAppAccessToken

    调用 axios 请求获取接口凭证

    const axios = require('axios')
    const { config } = require("dotenv")
    config()
    
    let data = {
        appId: process.env.appId,
        clientSecret: process.env.AppSecret
    }
    
    axios.post('https://bots.qq.com/app/getAppAccessToken', data)
        .then(res => {
            console.log(res.data)
        })
        .catch(err => {
    		console.log(err)
        })
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16

    请求错误:data: { code: 100016, message: ‘invalid appid or secret’ }

    acesss_token 返回结果示例

    data: {
    	access_token: '2HEWxcMy12Vc3ZC3yIgWxJcnilSp-gdXjtdLmP_yFief3wQMPQuWUzu5cFKhsAnIjPFRAUXPajLl',
    	expires_in: '7200'
    }
    
    • 1
    • 2
    • 3
    • 4

    在这里插入图片描述

    目前 access_token 生命周期默认 7200 秒,每次请求不会刷新新的 access_token,开发者需要在过期后自行刷新 access_token,保证调用链路权限正常。

    group 群接口调用

    在每次调用 https 的 openapi 开放接口请求的时候,需要在 header 内引入 access_token 进行调用权限验证。

    统一地址

    https://api.sgroup.qq.com
    
    • 1

    在这里插入图片描述

    QQ单聊 / QQ群聊

    发送消息分为,主动推送与被动回复,主动消息和被动消息在不同的场景下,发送的频次有不同的规则。 发送消息的接口有4个场景:QQ单聊、QQ群聊、文字子频道、频道私信。

    const axios = require('axios')
    const { config } = require("dotenv")
    config()
    
    const axiosconfig = {
        headers:{
            'Authorization': "QQBot wjy2j3CIDvFmN0HyPEPO-nwJOGpis2krvDtmxsiJwMKxI9lIY_ZoN73uVKtrMmViut_mHOdz70h8gw",
            'X-Union-Appid': "102075492",
        }
    };
    
    let data = {
        content: "Nonebot Perfect",
        msg_type: 0
    }
    
    axios.post('https://api.sgroup.qq.com/v2/groups/A85B11B27A39FB0C238B0F19FA09DDF7/messages', data, axiosconfig)
        .then(res => {
            console.log(res)
        })
        .catch(err => {
            console.log(err)
        })
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
  • 相关阅读:
    若依 vue版 刷新页面 404 回到网站首页 index页面的问题
    Universal Data Access Components (UniDAC) 9.3.0
    Smart UI Web 16.0.1 WebComponents htmlelements Crack
    【C/C++笔试练习】初始化列表、构造函数、析构函数、两种排序方法、求最小公倍数
    针对边缘计算,红帽企业Linux 9有哪些新功能?
    bRPC works with iRDMA && ICE on Fedora 37
    使用Python比较两张人脸图像并获得准确度
    Prometheus+Grafana实现服务性能监控:windows主机监控、Spring Boot监控、Spring Cloud Alibaba Seata监控
    894. All Possible Full Binary Trees
    2023长春大学计算机考研信息汇总
  • 原文地址:https://blog.csdn.net/qq_47452807/article/details/134317472