【Re:从零开始的QQ机器人搭建】—— 基于go-cqhttp

警告:小心智械危机(

前言

之前酷Q用的好好的,谁知道刚打完工会战不到2天tx就封了大部分机器人。所幸小部分有生力量保留了下来,必可活用于下次机器人搭建。

一、准备工作

你需要准备的只有两样东西:go-cqhttp 和 Python 环境
实际上不止python,任何语言都可搭建后台,本文仅使用python举例子

1.快速上手go-cqhttp

官方文档 https://docs.go-cqhttp.org

如果能自己看懂官方文档是最好,不过鉴于笔者在搭建的时候看的有点云里雾里,还是详细写下来吧。

  1. 文件安装
    点击 " 快速开始 "

    来到这里,点击release跳到下载地址

    在下面找到适合自己系统的文件,下载zip文件解压

    解压完应该会有如下的文件

  2. 文件配置
    我们先双击exe文件,打开,它会自动生成一个 config.yml 文件(两张图分别为运行exe文件时的图和运行完生成文件的图)


    然后我们第二次双击运行exe文件,这时候会正常运行并加载出二维码,以及自动生成一些文件
    到加载出二维码这里,你可以直接扫码登录,本教程后续在配置文件里输入账号密码,现在我们先不管这个二维码,直接关掉窗口

    红框内为新生成的文件,png是二维码,可以直接删掉,data和logs是本地记录,device.json是自动生成的设备信息,都不用管

    来到了最重要的一步,我们来配置 config.yml 这个文件,这是官方配置文档,可以自行看文档配置,文档看不懂也可以直接看下文傻瓜式教程

    双击 config.yml 用记事本打开

    打开之后显示如图,建议输入小号的账号密码来当机器人,注意密码要输入到两个单引号之间

    下列代码是心跳事件,大概原理是每隔xx秒向tx的服务器发送一条空信息,证明这个Q号还活着防止tx把我踢下线,不过如果是长时间使用的小号tx一般不会踢下线,可以关掉心跳事件(因为心跳会刷屏,有点烦)

    heartbeat:disabled: false # 是否开启心跳事件上报# 心跳频率, 单位秒# -1 为关闭心跳interval: 5
    

    下面是最重要的服务器配置 ,配置方法在注释中,理论上只需要改host,port和post就可以了(host和port可以不改,文件默认为127.0.0.1:5700,post一定要改,不然只能收到信息,无法发送信息)

    注意!改post的url和secret时一定要把前面的 # 号改成 两个空格 !以下代码可直接复制替换原文件中的对应部分

    servers:# HTTP 通信设置- http:# 是否关闭正向HTTP服务器disabled: false# 服务端监听地址,用来收QQ信息,可自己设置其它地址host: 127.0.0.1# 服务端监听端口,用来收QQ信息,可自己设置其它端口port: 5700# 反向HTTP超时时间, 单位秒# 最小值为5,小于5将会忽略本项设置timeout: 5middlewares:<<: *default # 引用默认中间件# 反向HTTP POST地址列表post:- url: '127.0.0.1:8000' # 这个url用来发送信息,可自己设置其它地址secret: ''           # 密钥不要写,就这样空着
    

    go-cqhttp 的安装和配置到此为止,你的机器人已经呼之欲出了

2.编程环境配置

本环节不做展开,你可以选择任何一种你喜欢的编程语言,只要能做到监听端口和发送post/get请求即可

二、HalloWorld(

下面来试着让机器人运作起来
监听端口使用Python 作为编程语言,其他语言原理差不多,可根据自己的需求来调整代码。

首先我们来看一下机器人的运作原理
先双击运行 go-cqhttp.exe(其实更好的方法是通过命令行运行 go-cqhttp,如下图,强烈建议这么做),出现下图的情景就说明机器人运行成功了

当有人对机器人发信息,或者在机器人所在的群里发信息的时候,机器人就会捕获信息和对应数据,我们来看看机器人传给我们的数据格式

本段是群聊信息的格式
{'anonymous': None,'font': 0,'group_id': , 这里显示群号'message': 'setu', 这里显示信息,本条信息为“setu”'message_id': -1345471362, 信息id,可用来撤回对应信息'message_seq': 474313, 'message_type': 'group', 信息类型,这里显示是群聊信息'post_type': 'message','raw_message': 'setu',这里显示原始信息,本条信息为“setu”,以后分析数据的时候直接分析这里就行'self_id': 3161879130,'sender': {'age': 0,'area': '','card': '', 信息发送者的群名片'level': '','nickname': '', 信息发送者的QQ昵称'role': 'admin','sex': 'unknown','title': '', 信息发送者的群头衔'user_id':  信息发送者的QQ号码},'sub_type': 'normal','time': 1619686099,'user_id': 信息发送者的QQ号码
}
本段是私聊信息的格式
{'font': 0,'message': 'setu',这里显示信息,本条信息为“setu”'message_id': -1964103618,信息id,可用来撤回对应信息'message_type': 'private',信息类型,这里显示是私聊信息'post_type': 'message','raw_message': 'setu',这里显示原始信息,以后分析数据的时候直接分析这里就行'self_id': 3161879130,'sender': {'age': 0,'nickname': '',信息发送者的QQ昵称'sex': 'unknown','user_id':  信息发送者的QQ号码},'sub_type': 'friend',信息发送者的分组,这里显示在“朋友”分组'target_id': , 目标QQ号码,就是你机器人的Q号'time': 1619687022,时间戳,不用管'user_id':  信息发送者的QQ号码
}

接着我们来创建两个py文件
第一个py文件(随便取什么名字),搭建一个微型服务器,用来监听和分析收到的信息

from flask import Flask, request'''注意,这里的import api是另一个py文件,下文会提及'''
import apiapp = Flask(__name__)'''监听端口,获取QQ信息'''
@app.route('/', methods=["POST"])
def post_data():'下面的request.get_json().get......是用来获取关键字的值用的,关键字参考上面代码段的数据格式'if request.get_json().get('message_type')=='private':# 如果是私聊信息      uid = request.get_json().get('sender').get('user_id') # 获取信息发送者的 QQ号码message = request.get_json().get('raw_message') # 获取原始信息api.keyword(message, uid) # 将 Q号和原始信息传到我们的后台if request.get_json().get('message_type')=='group':# 如果是群聊信息gid = request.get_json().get('group_id') # 获取群号uid = request.get_json().get('sender').get('user_id') # 获取信息发送者的 QQ号码message = request.get_json().get('raw_message') # 获取原始信息api.keyword(message, uid, gid) # 将 Q号和原始信息传到我们的后台return 'OK'if __name__ == '__main__':app.run(debug=True, host='127.0.0.1', port=8000)# 此处的 host和 port对应上面 yml文件的设置

第二个py文件用来实现 api 功能,可根据自己的需求手动编写api,我们把它命名为api.py
本api文档包含300英雄团分查询随机涩图
发送信息的原理简单来说就是向对应网址发送请求
我尽可能注释详细,希望读者看完能理解原理

import jsonimport requests
import re
import random'下面这个函数用来判断信息开头的几个字是否为关键词'
'如果是关键词则触发对应功能,群号默认为空'
def keyword(message, uid, gid = None):if message[0:3] == '300': # 300查团分, 格式为300+游戏名称,如 “300yaq”return zhanji(uid, gid, message[3:len(message)])if message[0:4] == 'setu': # 你们懂的setu()def zhanji(uid, gid, name):'本功能参考300英雄官方api文档写成''有不理解的地方可以看看https://300report.jumpw.com/static/doc/openapi.txt'url = 'https://300report.jumpw.com/api/getrole?name=' + namemenu = requests.get(url)for i in menu.json()['Rank']:if i['RankName'] == '团队实力排行':tuanfen = i['Value']if gid != None: # 如果是群聊信息requests.get(url='http://127.0.0.1:5700/send_group_msg?group_id={0}&message={1}团分{2}'.format(gid, name, tuanfen))else: # 如果是私聊信息requests.get(url='http://127.0.0.1:5700/send_private_msg?user_id={0}&message={1}团分{2}'.format(uid, name, tuanfen))''
def setu(): '本功能放在下面讲,这里的功能默认只有群聊,没考虑私聊,请把机器人拉进群再发消息''如果想实现私聊功能可以参考上面查战绩的代码'key = ''url = 'https://api.lolicon.app/setu?apikey=' + key + r'&size1200=true'menu = requests.get(url)setu_url = menu.json()['data'][0]['url'] # 对传回来的涩图网址进行数据提取requests.get(url='http://127.0.0.1:5700/send_group_msg?group_id={0}&message={1}'.format(gid, r'[CQ:image,' r'file=' + str(setu_url) + r']'))

我们来着重讲一下setu功能的实现,顺带来理解一下怎么使用所谓的cq码
setu的官方api文档 https://api.lolicon.app/#/setu

key = ''

这里的key要去申请,请参考官方文档,以下为可能遇到的问题:

  1. 初次添加@loliconApiBot会让你点击/start,点完之后你会发现没啥反应,这时你需要再输入一个/,就能申请apikey了。把申请到的apikey放到上面python代码中的key = ''里面就OK了

至于下面这行代码

requests.get(url='http://127.0.0.1:5700/send_group_msg?group_id={0}&message={1}'.format(gid, r'[CQ:image,' r'file=' + str(setu_url) + r']'))

message=后面的信息就是所谓的cq码
官方cq码api文档https://docs.go-cqhttp.org/cqcode/
简单来说,cq码是一种规范化的qq功能指令字符串,它能让你在机器人中实现@某人、发送图片、撤回信息、踢人出群等等一系列功能,我们只需要在message=后面输入cq码就能调用功能了
比如setu功能一定要用到 发送图片 的功能,我们的cq码格式就是

[CQ:image,file=]
file=后面跟的是图片的url地址,上面代码块的r'[CQ:image,' r'file=' + str(setu_url) + r']'作用就是把我们获取到的涩图地址填充进去

下面是演示

至此,基本功能原理大概都讲清楚了,读者可根据自己的喜好后续添加各种喜欢的api(比如祖安宝典,查天气,抽卡等等),希望有更多的QQ机器人开发者参与进来,也希望本教程能为你的机器人开发尽一份绵薄之力。如遇问题可在下方评论区留言。

【Re:从零开始的QQ机器人搭建】——基于go-cqhttp和python相关推荐

  1. 安卓原神QQ机器人搭建教程

    1,下载安装Termux 下载地址:https://f-droid.org/packages/com.termux/ 滑到下面点击这个 2,打开Termux,安装Ubuntu 安装模拟权限git,py ...

  2. python qq机器人框架有哪些_使用Python的Tornado框架实现一个简单的WebQQ机器人

    我打算将WebQQ单独出来运行, 一开始直接拷贝了pyxmpp2的mainloop, 但是跑起来问题多多, 所以我又研究了利用Tornado进行网络编程(这里), 所以我放弃了Pyxmpp2的main ...

  3. 2分钟实战QQ机器人教程(保姆级)手把手教你极速开发

    2022十二月最新版QQ机器人搭建 声明:本项目仅用于自动化测试,不可用于非法行为.且不承担一切法律责任. windows篇: 下载主程序:https://wwp.lanzouy.com/izUi20 ...

  4. 第十代晨风机器人_第十代QQ机器人下载_第十代QQ机器人 v20180102 官方版 - 西西下载...

    官方介绍: 第十代QQ机器人是对QQ进行功能扩展的程序,在第十代机器人软件登录QQ号码后可以按照预先设定的一些指令自动完成某些任务,例如与好友进行交流,执行一些数据交互任务,实现QQ与网站的交互,常用 ...

  5. 玩转多功能QQ机器人【含ChatGPT实现】

    ★★★ 本文源自AI Studio社区精品项目,[点击此处]查看更多精品内容 >>> 手把手实现多功能QQ机器人 现在网络上已经有很多的教程去教学QQ搭建,我这里再写一个完整的流程搭 ...

  6. python生成QQ机器人爬取百度文库链接推送好友并生成词云

    QQ机器人爬取百度文库链接推送好友并生成词云 一.环境准备 二.实现QQ机器人 1.QQ机器人介绍 2.安装方法 3.实现自己的QQ机器人 三.百度文库内容链接爬取推送好友 代码实现: 思路分析 1. ...

  7. Python机器人-QQ机器人-查询QQ报价?来看看你的QQ值多少钱!

    QQ报价查看你的QQ值多少钱!价格仅供参考,具体还需要大家查看市场价格.本文只用于教程,大家可以自己做一个用来查看QQ价格,丰富自己QQ机器人的功能呢!什么?你不会QQ机器人? 那就看我上一篇论文呢! ...

  8. 基于Nonebot2搭建QQ机器人(一)机器人环境配置

    目录 一.Nonebot2介绍 二.Nonebot2安装 1.bot.py文件的配置 2..env文件的配置 3.env.dev文件配置 4.env.pord配置 三.go-cqhttp介绍 四.go ...

  9. 基于Mirai搭建QQ机器人监控B站直播

    搭建自定义Mirai机器人 周末本来想继续学Vue来着,这不又搞这个了,唉,这计划赶不上变化啊. 参考文档 mamoe/mirai: 高效率 QQ 机器人支持库 Gradle 下载的依赖jar包在哪? ...

最新文章

  1. CNN 的一些可视化方法!
  2. win7安装redis
  3. 博科:毫不迟疑地入软件网络时代
  4. io流图解 java_详细讲解JAVA中的IO流
  5. TinyFrame升级之五:全局缓存的设计及实现
  6. Python 数据分析三剑客之 NumPy(六):矩阵 / 线性代数库与 IO 操作
  7. session.merge 缓存不更新_如何保证缓存与数据库双写时的数据一致性?
  8. python生成exe启动很慢,win2000上的python启动非常慢
  9. 一文看懂机器视觉工业相机与普通相机的区别
  10. hdu1695 容斥原理 莫比乌斯反演
  11. 忘记mysql管理密码怎么办?
  12. Android Studio新建工程syncing失败;Android studio Connection timed out: connect
  13. 【离散数学】集合论 第三章 集合与关系(2) 集合的基本运算
  14. 用计算机算cos1,cos计算器(数学三角函数计算器)
  15. 关于电的计算机公式,关于电的计算公式 所有注意,是所有!什么功率、电流、电阻、.对不起,我要的是全部,而且不要光是字母公式,而且请注明单位...
  16. Linux环境编程05
  17. 基于ESXi的软路由(LEDE)与黑群晖的安装与配置
  18. XXU邮箱,和客户端同步 pku
  19. Spring-setter注入和构造器注入
  20. Ubuntu 20.10 安装 gcc, g++,clang,make,make-guile

热门文章

  1. REVIT按草图绘制楼梯(楼梯篇)
  2. 数据结构与算法分析学习笔记
  3. Lua 面向对象基础-类和对象(一)
  4. IDEA使用 —— 快捷键篇
  5. MyBatis的<trim></trim>标签及prefix,suffix,suffixOverrides
  6. 有没有开源h5版本的在线cad软件
  7. 【机器学习】Logistic回归---学习笔记(重新整理)
  8. 读取word中表格的数据
  9. 模拟生态圈_模拟生态系统的建立研究
  10. stm32控制共阳数码管以及共阴数码管