如何用Python开发QQ机器人
作者:应用开发 来源:域名 浏览: 【大中小】 发布时间:2025-11-05 02:41:13 评论数:

前言
虽然该文最终是何用达到以python开发mirai机器人的目的,但起步教程,机器尤其是何用环境配置上仍然有大量的相同操作,对其他编程语言仍有借鉴之处 假设你已经安装好了 Java、机器Python等运行必须的何用环境mirai生态
mirai官方生态文档[1] 要使用mirai开发QQ机器人,首先要对其生态有一定的机器了解,因为它太复杂了,何用坑特别多,机器所以多了解一点,何用遇到问题之后解决起来也会更快 mirai生态汇总图


起步
使用 mirai-console-loader 启动 mirai-console
根据上面的介绍,要开发一个mirai的QQ机器人,我们首先需要将mirai-console给运行起来,而要做到这一步,可难。例如你需要准备mirai-core,mirai-console 和 mirai-console-terminal,然后还需要通过一大串指令来启动它。 而官方显然考虑到这一点,为了挽回被这一高难度操作劝退的萌新,官方又推出了mirai-console-loader(简称mcl) —— mirai-console 的官方一键启动器。因此你仅需要下载它即可(第一步说的都不用管0.0)。github仓库位置:mirai-console-loader[2] 下载完成mcl之后,解压、打开cmd、切换到mcl所在目录、运行mcl。如下图:


使用 mirai-login-solver-selenium 处理滑块验证辅助登录
在成功启动的mcl窗口,运行命令登录qq:login 账号 密码 应该是会出错的,因为mirai-console在登录时,不能处理滑块验证:
1. 查看cmd窗口,找到mcl正在下载的chromedriver是什么版本

2. 然后去chromedriver的另一个镜像源下载,推荐:chromedriver[4]
3. 找到一个版本号相近的即可,例如我就下载 86.0.4240.22

4. 将下载好的文件解压,再重命名成chromedriver-86.0.4240.198.exe,也就是刚刚我们在命令行窗口查看的文件名,一定要跟它想下载的文件名一致
5. 结束之前运行的mcl命令行程序,然后将准备好的chromedriver-86.0.4240.198.exe, 替换到以下目录
6. 重新运行mcl程序,如果一切顺利,就可以继续之前的步骤,输入命令:login 账号 密码 尝试登录。接下来会弹出一个浏览器窗口,你只需要傻瓜式的完成登录验证即可。如果登录成功,以后的每次登录,应该都是不需要再次验证的。
又跨过一个坎…接下来就到了另外一个坎使用 mirai-api-http 增加语言拓展性 (为了能用其他语言来开发)
前面一直在说 mirai-api-http,但是到目前为止,我们都还没有用上它。前面的工作就做了两个事情1. 使用mcl运行mirai-console
2. 使用 mirai-login-solver-selenium 辅助通过滑块验证码,完成登录
那么接下来就开始用mirai-api-http,首先在mirai-api-http项目地址,下载mirai-api-http[5] 然后将下载到的jar包,放在plugin文件夹下,如图

1. 下载 open JDK[6],例如我下载如图所示的版本:

2. 解压open JDK, 并放在你认为合适的位置,例如我放在如下图所示的位置:

3. 添加 jdk 所在路径到环境变量:此电脑 ->右键属性 -> 高级系统设置 -> 高级 -> 环境变量, 再按下图操作


通过 graia-application-mirai 使用 python 开发 mirai 机器人
前面的操作,直到该步为止,基本对所有使用除java/kotlin语言的程序员,都是通用的。而后面的操作,仅写给使用python的程序员 graia-application-mirai官方文档[7] 首先对mirai-api-http进行配置,如图:
pip install graia-application-mirai
将以下代码复制到bot.py,按注释提示,再结合刚刚对mirai-api-http的配置,稍作修改。然后运行 from graia.broadcast import Broadcast from graia.application import GraiaMiraiApplication, Session from graia.application.message.chain import MessageChain import asyncio from graia.application.message.elements.internal import Plain from graia.application.friend import Friend loop = asyncio.get_event_loop() bcc = Broadcast(looploop=loop) app = GraiaMiraiApplication( broadcast=bcc, connect_info=Session( host="http://localhost:8080", # 填入 httpapi 服务运行的地址 authKey="graia-mirai-api-http-authkey", # 填入 authKey account=5234120587, # 你的机器人的 qq 号 websocket=True # Graia 已经可以根据所配置的消息接收的方式来保证消息接收部分的正常运作. ) ) @bcc.receiver("FriendMessage") async def friend_message_listener(app: GraiaMiraiApplication, friend: Friend): await app.sendFriendMessage(friend, MessageChain.create([ Plain("Hello, World!") ])) app.launch_blocking() 然后向你的QQ机器人,随便发送一条消息,如果它回复你Hello, World!,则表示运行成功 成功所示如下:
结语
上面的全部操作,不过是使用mirai进行开发QQ机器人的起步教程而已,需要了解更多,还是去阅读官方文档,以学习更多的api。
