新版nonebot,go-cqhttp搭建qq机器人保姆级教程

新版nonebot,go-cqhttp搭建qq机器人保姆级教程

news/2024/5/26 20:26:32/

前言

前段时间QQ进行了更新,所以导致了非手表协议扫码登陆报错的问题,不过好在大佬已经推出rc5版本的go-cqhttp,解决了这一头疼的问题

在开始之前,我需要说明一下,本文章是针对没有经验和基础的用户,所以说篇幅可能会长一点

开始

1.准备

你需要准备的东西有:

  1. python3.8及以上版本
  2. 虚拟环境(可选)
  3. nonebot框架
  4. go-cqhttp客户端
  5. 机器人账户
  6. 一定的python基础

如果你有python的基础,那么你一定知道pypi,pypi其实可以说是python的官方应用商店,里面有许多第三方模块可供下载,而我们的主角 Nonebot便是其中的一个第三方模块

2.安装nonebot

安装官方手脚架:nb-cli

这里我推荐没有经验的人使用官方的手脚架来安装nonebot及适配器,如果你有经验,那当我没说。个人还是觉得官方手脚架用起来会方便一点

手脚架安装命令:pip install nb-cli

安装截图

安装成功截图

如果你按照我的步骤来,那么应该已经成功安装了手脚架,接下来就是如何去使用手脚架了

使用手脚架安装框架

首先我们需要安装驱动器

我们先使用命令查看驱动器列表,命令如下

nb driver list

终端输出如下

可以看到有很多驱动器,这里我们选择httpx,同样的输入下列命令进行安装

nb driver

终端输出结果

我们选择第三个“安装驱动器到当前项目”,此处可以用键盘上下方向键进行选择,我们移到第三个回车,并且输入httpx

终端输出

如上图所示我们已经成功安装了httpx驱动器,接下来就是安装适配器了

输入下列命令查看适配器列表

nb adapter list

输出如图所示

本次教程是搭建qq机器人,如果你想要在微信或者其他平台搭建机器人的话请自行尝试。

我们选择的适配器是 OneBot V11,V12因为博主也没试过,所以不敢给你们推荐

输入如下命令安装适配器

nb adapter

这里我们选择“安装适配器”到当前项目,同样的键盘上下键选择并回车

终端输出如图所示

我们再次输入 pip list 输出如图所示:

可以看到我们成功安装了适配器和框架本身,如果结果跟博主一样的话,恭喜你,至此你已经完成了框架及适配器的安装

3.创建项目

那么我们已经完成了框架的安装,接下来就是创建项目了,前文我们已经安装了官方手脚架,所以我们可以通过手脚架来创建项目

命令如下

nb create

注意,这里我们要记得cd到项目文件夹

例如我要把项目建在D盘的python开发目录下,那么我就要cd到该目录再执行命令

如上图,这里因为我比较熟悉simple,所以我们选用simple模板

项目名称你们自己起,最好是英文。

驱动器我们选择FastAPI

适配器我们选择OneBot V11

这里我们选择再src目录下存放插件

是否立即安装依赖填y,创建虚拟环境可选

如图所示你就已经成功创建了一个bot项目了🎉

项目结构如下

📦 AweSome-Bot
├── 📂 awesome_bot         # 或是 src
│   └── 📜 plugins
├── 📜 .env                # 可选的
├── 📜 .env.dev            # 可选的
├── 📜 .env.prod           # 可选的
├── 📜 .gitignore
├── 📜 bot.py
├── 📜 docker-compose.yml
├── 📜 Dockerfile
├── 📜 pyproject.toml
└── 📜 README.md

资源管理器截图

如果你的结构跟我一样,那么恭喜你,已经成功的创建好一个项目了,接下来就是配置了

配置

.env文件内容修改为

ENVIRONMENT=prod

.env.dev文件内容修改为

HOST=127.0.0.1
PORT=8080
LOG_LEVEL=DEBUG
FASTAPI_RELOAD=true

需要注意的是,如果你是Linux环境,请修改.env.dev文件

FASTAPI_RELOAD=false

除FASTAPI_RELOAD=false外其余均保持默认

4.安装go-cqhttp

go-cqhttp你可以理解为一个qq客户端

下载地址:Releases · Mrs4s/go-cqhttp (github.com)

截止本文写成之时go-cqhttp最新版本为rc5

本次教程针对win系统,所以我们下载红框框起来的安装包

下载后双击运行生成bat文件

可以看到,在目录下生成了一个bat文件

在后续使用过程我们都需要使用bat文件而不是运行本体,双击运行bat文件

这里我们选择 3 反向 Websocket 通信

可以看到提示我们修改配置文件再重启

config.yml默认配置

# go-cqhttp 默认配置文件account: # 账号相关uin: 1233456 # QQ账号password: '' # 密码为空时使用扫码登录encrypt: false  # 是否开启密码加密status: 0      # 在线状态 请参考 https://docs.go-cqhttp.org/guide/config.html#在线状态relogin: # 重连设置delay: 3   # 首次重连延迟, 单位秒interval: 3   # 重连间隔max-times: 0  # 最大重连次数, 0为无限制# 是否使用服务器下发的新地址进行重连# 注意, 此设置可能导致在海外服务器上连接情况更差use-sso-address: true# 是否允许发送临时会话消息allow-temp-session: false# 是否禁用协议更新disable-protocol-update: falseheartbeat:# 心跳频率, 单位秒# -1 为关闭心跳interval: 5message:# 上报数据类型# 可选: string,arraypost-format: string# 是否忽略无效的CQ码, 如果为假将原样发送ignore-invalid-cqcode: false# 是否强制分片发送消息# 分片发送将会带来更快的速度# 但是兼容性会有些问题force-fragment: false# 是否将url分片发送fix-url: false# 下载图片等请求网络代理proxy-rewrite: ''# 是否上报自身消息report-self-message: false# 移除服务端的Reply附带的Atremove-reply-at: false# 为Reply附加更多信息extra-reply-data: false# 跳过 Mime 扫描, 忽略错误数据skip-mime-scan: false# 是否自动转换 WebP 图片convert-webp-image: falseoutput:# 日志等级 trace,debug,info,warn,errorlog-level: warn# 日志时效 单位天. 超过这个时间之前的日志将会被自动删除. 设置为 0 表示永久保留.log-aging: 15# 是否在每次启动时强制创建全新的文件储存日志. 为 false 的情况下将会在上次启动时创建的日志文件续写log-force-new: true# 是否启用日志颜色log-colorful: true# 是否启用 DEBUGdebug: false # 开启调试模式# 默认中间件锚点
default-middlewares: &default# 访问密钥, 强烈推荐在公网的服务器设置access-token: ''# 事件过滤器文件目录filter: ''# API限速设置# 该设置为全局生效# 原 cqhttp 虽然启用了 rate_limit 后缀, 但是基本没插件适配# 目前该限速设置为令牌桶算法, 请参考:# https://baike.baidu.com/item/%E4%BB%A4%E7%89%8C%E6%A1%B6%E7%AE%97%E6%B3%95/6597000?fr=aladdinrate-limit:enabled: false # 是否启用限速frequency: 1  # 令牌回复频率, 单位秒bucket: 1     # 令牌桶大小database: # 数据库相关设置leveldb:# 是否启用内置leveldb数据库# 启用将会增加10-20MB的内存占用和一定的磁盘空间# 关闭将无法使用 撤回 回复 get_msg 等上下文相关功能enable: truesqlite3:# 是否启用内置sqlite3数据库# 启用将会增加一定的内存占用和一定的磁盘空间# 关闭将无法使用 撤回 回复 get_msg 等上下文相关功能enable: falsecachettl: 3600000000000 # 1h# 连接服务列表
servers:# 添加方式,同一连接方式可添加多个,具体配置说明请查看文档#- http: # http 通信#- ws:   # 正向 Websocket#- ws-reverse: # 反向 Websocket#- pprof: #性能分析服务器# 反向WS设置- ws-reverse:# 反向WS Universal 地址# 注意 设置了此项地址后下面两项将会被忽略universal: ws://your_websocket_universal.server# 反向WS API 地址api: ws://your_websocket_api.server# 反向WS Event 地址event: ws://your_websocket_event.server# 重连间隔 单位毫秒reconnect-interval: 3000middlewares:<<: *default # 引用默认中间件

这里我们需要配置qq号以及密码,还有反向服务器地址

还记得上一步我们配置的.env.dev吗,是不是端口为8080,所以 universal 参数应该这样配置,如果你自行配置了端口号,那么请自行修改一下哦

universal: ws://127.0.0.1:8080/onebot/v11/ws/

config.yml完整配置(这里账密没有配置,记得自行配置一下哦)

# go-cqhttp 默认配置文件account: # 账号相关uin:  # QQ账号password:  # 密码为空时使用扫码登录encrypt: false  # 是否开启密码加密status: 0      # 在线状态 请参考 https://github.com/Mrs4s/go-cqhttp/blob/dev/docs/config.md#在线状态relogin: # 重连设置disabled: falsedelay: 3      # 重连延迟, 单位秒interval: 0   # 重连间隔max-times: 0  # 最大重连次数, 0为无限制# 是否使用服务器下发的新地址进行重连# 注意, 此设置可能导致在海外服务器上连接情况更差use-sso-address: trueheartbeat:disabled: false # 是否开启心跳事件上报# 心跳频率, 单位秒# -1 为关闭心跳interval: 5message:# 上报数据类型# 可选: string,arraypost-format: string# 是否忽略无效的CQ码, 如果为假将原样发送ignore-invalid-cqcode: false# 是否强制分片发送消息# 分片发送将会带来更快的速度# 但是兼容性会有些问题force-fragment: false# 是否将url分片发送fix-url: false# 下载图片等请求网络代理proxy-rewrite: ''# 是否上报自身消息report-self-message: false# 移除服务端的Reply附带的Atremove-reply-at: false# 为Reply附加更多信息extra-reply-data: falseoutput:# 日志等级 trace,debug,info,warn,errorlog-level: warn# 是否启用 DEBUGdebug: false # 开启调试模式# 默认中间件锚点
default-middlewares: &default# 访问密钥, 强烈推荐在公网的服务器设置access-token: ''# 事件过滤器文件目录filter: ''# API限速设置# 该设置为全局生效# 原 cqhttp 虽然启用了 rate_limit 后缀, 但是基本没插件适配# 目前该限速设置为令牌桶算法, 请参考:# https://baike.baidu.com/item/%E4%BB%A4%E7%89%8C%E6%A1%B6%E7%AE%97%E6%B3%95/6597000?fr=aladdinrate-limit:enabled: false # 是否启用限速frequency: 1  # 令牌回复频率, 单位秒bucket: 1     # 令牌桶大小servers:# HTTP 通信设置- http:# 是否关闭正向HTTP服务器disabled: false# 服务端监听地址host: 127.0.0.1# 服务端监听端口port: 5701# 反向HTTP超时时间, 单位秒# 最小值为5,小于5将会忽略本项设置timeout: 5middlewares:<<: *default # 引用默认中间件# 反向HTTP POST地址列表post:#- url: '' # 地址#  secret: ''           # 密钥#- url: 127.0.0.1:5701 # 地址#  secret: ''          # 密钥# 正向WS设置- ws:# 是否禁用正向WS服务器disabled: false# 正向WS服务器监听地址host: 127.0.0.1# 正向WS服务器监听端口port: 6701middlewares:<<: *default # 引用默认中间件- ws-reverse:# 是否禁用当前反向WS服务disabled: false# 反向WS Universal 地址# 注意 设置了此项地址后下面两项将会被忽略universal: ws://127.0.0.1:8080/onebot/v11/ws/# 反向WS API 地址api: ws://your_websocket_api.server# 反向WS Event 地址event: ws://your_websocket_event.server# 重连间隔 单位毫秒reconnect-interval: 3000middlewares:<<: *default # 引用默认中间件# pprof 性能分析服务器, 一般情况下不需要启用.# 如果遇到性能问题请上传报告给开发者处理# 注意: pprof服务不支持中间件、不支持鉴权. 请不要开放到公网- pprof:# 是否禁用pprof性能分析服务器disabled: true# pprof服务器监听地址host: 127.0.0.1# pprof服务器监听端口port: 7700# 可添加更多#- ws-reverse:#- ws:#- http:#- pprof:database: # 数据库相关设置leveldb:# 是否启用内置leveldb数据库# 启用将会增加10-20MB的内存占用和一定的磁盘空间# 关闭将无法使用 撤回 回复 get_msg 等上下文相关功能enable: true

账户密码记得修改,修改完成后双击运行bat按照终端输出提示来完成登录,这里就不作演示了

5.运行!!!成功!!

启动nonebot

我们cd到之前第三步创建项目时的文件夹,例如我是yuan文件夹

输入如下命令来运行

nb run --reload

输入命令回车后你应该会看到如下结果

启动go-cqhttp

在进行这一步前,请确认你已经完成了对config.yml的配置,这里我默认你已经完成了配置

同样的,双击运行bat文件稍等几秒后如果配置没有问题,那么你将看到如下结果

前面的报错不用管,那是因为我先启动的gocq,而nonebot框架是作为服务端,没有启动gocq自然连不上,所以报错。而红框框起部分就是启动了nonebot的时候

如果你的输出结果也是如此,那么太棒了,你成功搭建好了机器人,接下来我们安装个简单插件试试bot能不能正常运行

拿我写的一个插件为例子,输入下列命令安装

nb plugin install nonebot-plugin-yuanshen-notice

安装完成后重新运行 nb run --reload ,如果操作正确,你将看到下面的结果

看提示,是不是成功导入了nonebot-plugin-yuanshen-notice?再看最后一行,connection open,说明此时nonebot已经和go-cq握手成功了,下面我们来测试一下

发送原神公告,如果操作无误将看到下列结果

如果你也得到了这样的反馈,那么恭喜你,成功搭建好了机器人,至此,搭建机器人的工作就圆满结束了,本教程使用的是win系统,后续考虑推出linux教程,还请各位多多支持

结尾

很高兴你能看完本教程,怎么样?你应该也学会如何搭建机器人了吧,后续博主也会出视频教程,插件编写教程,让我们尽情期待把!


http://www.ppmy.cn/news/846231.html

相关文章

用Nonebot2搭建QQ机器人(一):我的学习经历(一)

1.NoneBot2的概述&#xff1a; NoneBot2 是一个现代、跨平台、可扩展的 Python 聊天机器人框架&#xff0c;它基于 Python 的类型注解和异步特性&#xff0c;能够为你的需求实现提供便捷灵活的支持。然后剩下的详细说明建议自己去翻文档&#xff0c;我不多做赘述。 注意&…

新版傻妞+对接onebot协议+对接青龙+对接芝士保姆教程【2022年4月24更新】

此文章引用大佬的教程&#xff0c;进行更详细的阐述。交流群550894783 没有计算机专业基础&#xff0c;或者看不懂本教程&#xff0c;可进群找群主代搭建。 xdd 青龙 阿东 看我主页的其他文章 自己也踩坑了很久 才安装好。 其实有很多内容没写&#xff0c;容易劝学&#xf…

ModuleNotFoundError: No module named ‘nonebot.adapters.onebot’

安装适配器解决 pip install nonebot-adapter-onebot 如果还是报这个错&#xff0c;上大招&#xff0c;卸载重装 pip uninstall nonebot pip uninstall nonebot2 pip uninstall nb-cli pip install nb-cli pip install nonebot-adapter-onebot ModuleNotFoundError: No mod…

2022新版完整版青龙面板对接机器人,傻妞对接onebot(oicq)协议实现机器人功能

服务器租用推荐腾讯云、阿里云 传送门&#xff1a; 腾讯云 阿里云 前置教程2022年最新一篇文章教你青龙面板拉库,拉取单文件,安装依赖,设置环境变量,解决没有或丢失依赖can‘t find module之保姆教程(附带几十个青龙面板脚本仓库) 1.安装sillyGirl傻妞 请确保教程中你使用的…

青龙2.10.13 稳定版+Ninja登录面板+傻妞+OneBot机器人 保姆级教程【2022/7/1】

一直有朋友问技术问题&#xff0c;刚刚创建了个技术交流群&#xff0c;欢迎大家来讨论&#xff0c;qq群862536400 1号机器人&#x1f916;️&#xff1a;3584915428 2号机器人&#x1f916;️&#xff1a;3179818507 之前说要更新一篇青龙教程&#xff0c;最近一直在忙着一堆琐…

【2022-9-21最新】青龙面板搭建+sillyGirl+对接微信公众号+onebot

目录 前言技术交流裙&#xff1a;[点我](http://qm.qq.com/cgi-bin/qm/qr?_wv1027&krDMT3J904PwXNPNdXMeYbjSrJ9w2M4DC&authKey9j9rwijzU3T45rmb3aZ0F70DwGMzN4Qt/4cjKrFdtweTCRFVxyaxwE3ahmZCscVg&noverify0&group_code67054486)线报分享裙&#xff1a;[点我…

青龙面板+新版傻妞sillyGirl+onebot反向对接傻妞(22年3月2日更新)

搭建前提&#xff1a; 1.自备服务器&#xff0c;安全组打开5700 8080 8888 这3个端口 2.搭建宝塔&#xff0c;如何搭建宝塔&#xff0c;去宝塔官网拉取 3.进入宝塔在软件商城里下载 docker 4.下载好之后就可以执行下面的任务了 搭建青龙面板 &#xff08;我这个版本是2…

青龙2.10.13 稳定版+对接傻妞教程+短信登录+傻妞WEB控制台 超级详细

此文章引用大佬的教程&#xff0c;进行更详细的阐述。如有疑问请进交流群332461037 我用的系统是centos7.6 目录 一.重装系统 1.选择centos7.6系统 2.重置服务器密码 3.服务器开放端口 二.ssh工具远程连接服务器 1.下载xshell 7或者宝塔ssh 三.安装docker容器 1.ssh工…

c语言可变形参

一般的函数的参数列表都是固定的&#xff0c;但是偶尔也会想要根据情况使用动态的列表。 1.可变形参的形式 返回类型 函数名(第一个参数, ...); 可变形参的函数如上&#xff0c;需要提供第一个参数&#xff0c;后面用... 2.函数用到的特殊东西 va_list是一种特殊的指针&am…

MySQL数据库的备份与还原、视图基础操作

一、备份与还原 1、使用mysqldump命令备份数据库中的所有表 mysqldump -uroot -p#$%#*#^* booksDB authorbook authors books > /backup/db/booksDB.spl 2、备份booksDB数据库中的books表 mysqldump -uroot -p*&*&……%&#xffe5;#&#xffe5;% booksDB books …

主板维修测试软件,主板维修关键测试点(强烈推荐)

马上注册,获取阅读精华内容及下载权限 您需要 登录 才可以下载或查看,没有帐号?注册 x 主板维修关键测试点 触发故障 1: ATX第9脚5VSB,PCI槽A14脚3.3VSB,3,3VSB 一般由1117或1084MOS管转换 2:CMOS跳帽2.5V以上电压, 3:触发排针2.5V以上电压, 4:南桥晶振32.768是否起振…

计算机bios英文翻译,bios中英文对照表

bios主板设置很多用户都看不懂英文&#xff0c;新版本的主板基本上都可以中文英文翻译&#xff0c;但是很多老板只有英文&#xff0c;今天小编就给大家带来了想想的图文表翻译&#xff0c;下面来看看想想的教程吧。 bios中英文对照表图文翻译 1、进入BIOS默认在主要信息界面&am…

英语计算机主板接口有,主板上常见英文的解释

我本人英语也不是很好 ,非常理解英语差的朋友的心情。为此,我特意在网上搜集了一些有关,计算机主板上的常见英文解释.希望对你有所帮助 34,及39,40样数字指示。我们使用的软驱线和硬盘线红线靠近1的位置。  CPU插座:SOCKET-478和SOCKET462,SOCKET 370 表示CPU的类型的…

计算机主板的英文,电脑主板英文标识是什么意思?不同的标识各代表什么功能?...

一、风扇接口类&#xff1a; CPU_FATN1-------CPU风扇 PWR_FAN1-------电源风扇 CAS_FAN1和CHASSIS FAN和SYS FAN等-----表示机箱风扇电源接口。 FRONT FAN-------前置机箱风扇 REAR FAN-------后置机箱风扇 二、面板接口类&#xff1a; F_PANEL或FRONT PNL1------前置面板接…

Spring窥探系列之Bean生命周期(100%GPT生成版)

生命周期概览 Spring Bean 的生命周期可以分为以下阶段&#xff1a; 实例化&#xff1a;Spring 容器根据 Bean 的定义创建一个 Bean 的实例。这个阶段主要涉及 Bean 的实例化和依赖注入。 相关类&#xff1a;InstantiationAwareBeanPostProcessor、BeanFactoryPostProcessor、…

springboot结合疫情情况的婚恋系统

开发语言&#xff1a;Java 框架&#xff1a;springboot JDK版本&#xff1a;JDK1.8 服务器&#xff1a;tomcat7 数据库&#xff1a;mysql 5.7&#xff08;一定要5.7版本&#xff09; 数据库工具&#xff1a;Navicat11 开发软件&#xff1a;eclipse/myeclipse/idea Maven…

技术网站小结

黑客基地 华夏黑客同盟 黑客x档案官方论坛 中国x黑客小组 中国黑客联盟 黑客动画吧 红色黑客联盟 黑客技术 黑客城技术论坛 爱国者黑客 黑客手册 黑客风云 黑客领域 Yes黑客联盟 中华隐士黑客联盟 我爱黑客网 天天安全 E言E行黑客龙脉 黑客频…

南京美食

“芳婆”糕团店    王府大街50号自制生日蛋糕的店:   山西路仁和街走到底, 三乐电器厂旁的一品轩虎啸花园店 电话:3715221好粥道        长白街413号 TEL:4403301八喜茶餐厅&#xff08;粤菜&#xff09;  在王府大街毛家饭店斜对面&#xff0c;王府大街 “杰…

端午节(附屈原详介)

端午节简介:  农历五月初五,是中国民间的传统节日——端午节,它是中华民族古老的传统节日之一。端午也称端五,端阳。此外,端午节还有许多别称,如:午日节、重五节,五月节、浴兰节、女儿节,天中节、地腊、诗人节、龙日等等。虽然名称不同,但总体上说,各地人民过节的…

[转]我在上海的五年奋斗岁月

前言&#xff1a;刚刚看了坛子里有的兄弟关于相亲的苦恼&#xff0c;想起自己在上海这五年的经历&#xff0c;不由感慨颇多。 这位兄弟的这些苦恼&#xff0c;曾几何时也占据了我的头脑&#xff0c;让我痛苦不堪。然而&#xff0c;如今回首看来&#xff0c;这五年来也这是这些苦…