網(wǎng)站首頁 編程語言 正文
go-cqhttp安裝
一、 簡介
1、 介紹
官方文檔地址:https://docs.go-cqhttp.org/
各種框架都只是機(jī)器人的各種實(shí)現(xiàn),每個框架之間接口都不通用,編程語言也不盡相同,想要開發(fā)一個自己的機(jī)器人,換一套框架所有的代碼都要推到重來,所以亟需一個規(guī)范統(tǒng)一各個框架,所以O(shè)neBot 誕生了,先來看看OneBot 是啥:
OneBot 標(biāo)準(zhǔn):
一個聊天機(jī)器人應(yīng)用接口標(biāo)準(zhǔn)
簡單:
接口簡單易懂,可輕松接入。
兼容性:
兼容原 CQHTTP 插件,零負(fù)擔(dān)遷移。
兼容原 CQHTTP 插件,這個標(biāo)準(zhǔn)和CQHTTP有啥關(guān)系?CQHTTP是酷Q的一個插件,這個插件可以提供HTTP協(xié)議的接口供第三方系統(tǒng)調(diào)用,這樣就和具體語言無關(guān),什么語言都可以調(diào)用機(jī)器人接口實(shí)現(xiàn)自己的邏輯,而且基于CQHTTP 已經(jīng)實(shí)現(xiàn)了很多功能的機(jī)器人了,詳情見上面優(yōu)秀機(jī)器人框架,為了不讓以前所有的優(yōu)秀代碼都要推倒重來,所以O(shè)neBot 干脆直接在CQHTTP 的基礎(chǔ)之上指定標(biāo)準(zhǔn),這就是典型的先有實(shí)現(xiàn),后有標(biāo)準(zhǔn)的例子。
在這個標(biāo)準(zhǔn)的基礎(chǔ)之上,有了各種編程語言的實(shí)現(xiàn),我們稱之為生態(tài),如下:
理論上,基于 OneBot 標(biāo)準(zhǔn)開發(fā)的任何 SDK、框架和機(jī)器人應(yīng)用,都可以無縫地在下面的不同實(shí)現(xiàn)中切換。當(dāng)然,在一小部分細(xì)節(jié)上各實(shí)現(xiàn)可能有一些不同,這也是本項(xiàng)目希望推動解決的問題。
MiraiGo就是GO語言實(shí)現(xiàn)的安卓QQ協(xié)議,API很原始,相當(dāng)于一個類庫,go-cqhttp是在MiraiGo的基礎(chǔ)之上封裝的HTTP協(xié)議和Websocket協(xié)議接口的框架,得益于GO語言先天的優(yōu)勢(資源占用少,運(yùn)行簡單,協(xié)程并發(fā)高),總之就是性能高,引用項(xiàng)目原話 :
性能體現(xiàn):
- 在關(guān)閉數(shù)據(jù)庫的情況下, 加載 25 個好友 128 個群運(yùn)行 24 小時后內(nèi)存使用為 10MB 左右. 開啟數(shù)據(jù)庫后內(nèi)存使用將根據(jù)消息量增加 10-20MB, 如果系統(tǒng)內(nèi)存小于 128M 建議關(guān)閉數(shù)據(jù)庫使用. 2、 優(yōu)點(diǎn)
接口:
- HTTP API
- 反向HTTP POST
- 正向WebSocket
- 反向WebSocket
拓展支持:
- HTTP POST多點(diǎn)上報
- 反向WS多點(diǎn)連接
- 修改群名
- 消息撤回事件
- 解析/發(fā)送 回復(fù)消息
- 解析/發(fā)送 合并轉(zhuǎn)發(fā)
- 使用代理請求網(wǎng)絡(luò)圖片
搭建的文檔地址:https://docs.go-cqhttp.org/guide/quick_start.html
二、 Windows 搭建
1、 下載
在發(fā)行版中:https://github.com/Mrs4s/go-cqhttp/releases
找到屬于自己系統(tǒng)的可執(zhí)行文件,然后進(jìn)行下載:
下載后,我們得到這么一個文件:
2、 配置
然后,我們雙擊打開:
我們直接選擇0,僅使用HTTP通信:
在同級目錄下,生成了一個config.yml
的配置文件
我們使用記事本打開這個配置文件:
打開文件后,我們暫時只需要修改兩處
第一處,修改第4行和第5行:
第二處,將第108行和第109行的注釋解開:
其為用來監(jiān)聽消息的路由,后面我們使用flask,開啟該路由,來使得qq的消息可以傳入后臺,使我們可以處理
3、 登錄
再次雙擊我們的exe文件
然后,我們先關(guān)閉該窗口,開始編寫我們的程序
4、 監(jiān)聽消息
我們先在根目錄上創(chuàng)建一個code文件夾
再在code文件夾中,創(chuàng)建main.py
以及script.py
兩個文件
main.py
中,寫入我們的代碼
#!/usr/bin/python3 # -*- coding: UTF-8 -*- __author__ = "A.L.Kun" __file__ = "main.py" __time__ = "2022/9/9 22:03" from flask import Flask, request from flask_restful import Resource, Api import script app = Flask(__name__) api = Api(app) class AcceptMes(Resource): def post(self): # 這里對消息進(jìn)行分發(fā),暫時先設(shè)置一個簡單的分發(fā) _ = request.json if _.get("message_type") == "private": # 說明有好友發(fā)送信息過來 uid = _["sender"]["user_id"] # 獲取發(fā)信息的好友qq號 message = _["raw_message"] # 獲取發(fā)送過來的消息 script.handle_private(uid, message) api.add_resource(AcceptMes, "/", endpoint="index") if __name__ == '__main__': app.run("0.0.0.0", "5701") # 注意,這里的端口要和配置文件中的保持一致
script.py
中,寫入我們的代碼
#!/usr/bin/python3 # -*- coding: UTF-8 -*- __author__ = "A.L.Kun" __file__ = "script.py.py" __time__ = "2022/9/9 22:04" import asyncio import httpx from datetime import datetime def handle_private(uid, message): # 處理私聊信息 if message: # 簡單的判斷,只是判斷其是否為空 asyncio.run(send(uid, f"你好呀,請問發(fā)消息給我有什么事情?\n回復(fù)時間:{datetime.now().strftime('%Y-%m-%d %H:%M:%S')}")) async def send(uid, message, gid=None): """ 用于發(fā)送消息的函數(shù) :param uid: 用戶id :param message: 發(fā)送的消息 :param gid: 群id :return: None """ async with httpx.AsyncClient(base_url="http://127.0.0.1:5700") as client: if gid is None: # 如果發(fā)送的為私聊消息 print(uid) params = { "user_id": uid, "message": message, } await client.get("/send_private_msg", params=params)
最后,我們可以測試一下,如果出現(xiàn)自動回復(fù),則說明,我們的機(jī)器人配置已經(jīng)基本完成了
三、 Linux 搭建
1、 下載
還是在發(fā)行版頁面進(jìn)行下載:https://github.com/Mrs4s/go-cqhttp/releases
根據(jù)版本選擇我們需要的壓縮包,然后進(jìn)行下載:
下載的命令:
mkdir bot # 創(chuàng)建bot目錄 cd bot # 進(jìn)入目錄中 wget https://github.com/Mrs4s/go-cqhttp/releases/download/v1.0.0-rc3/go-cqhttp_linux_amd64.tar.gz # 下載壓縮包 tar -xzvf go-cqhttp_linux_amd64.tar.gz # 然后進(jìn)行解壓縮
解壓縮完成后,我們得到三個文件
2、 配置
生成配置文件
然后,將我們的配置文件按照Windows上面的配置一樣進(jìn)行修改:
第四行,第五行設(shè)置QQ賬號和密碼
第108行和第109行的注釋解開:
使用:108
直接定位到第108行
3、 登錄
登錄成功后,關(guān)閉程序
4、 開放端口
開放5700和5701端口
firewall-cmd --zone=public --add-port=5700/tcp --permanent firewall-cmd --zone=public --add-port=5701/tcp --permanent firewall-cmd --reload
5、 監(jiān)聽消息
我們先在根目錄上創(chuàng)建一個code文件夾
再在code文件夾中,創(chuàng)建main.py
以及script.py
兩個文件
main.py
中,寫入我們的代碼
#!/usr/bin/python3 # -*- coding: UTF-8 -*- __author__ = "A.L.Kun" __file__ = "main.py" __time__ = "2022/9/9 22:03" from flask import Flask, request from flask_restful import Resource, Api import script app = Flask(__name__) api = Api(app) class AcceptMes(Resource): def post(self): # 這里對消息進(jìn)行分發(fā),暫時先設(shè)置一個簡單的分發(fā) _ = request.json if _.get("message_type") == "private": # 說明有好友發(fā)送信息過來 uid = _["sender"]["user_id"] # 獲取發(fā)信息的好友qq號 message = _["raw_message"] # 獲取發(fā)送過來的消息 script.handle_private(uid, message) api.add_resource(AcceptMes, "/", endpoint="index") if __name__ == '__main__': app.run("0.0.0.0", "5701") # 注意,這里的端口要和配置文件中的保持一致
script.py
中,寫入我們的代碼
#!/usr/bin/python3 # -*- coding: UTF-8 -*- __author__ = "A.L.Kun" __file__ = "script.py.py" __time__ = "2022/9/9 22:04" import asyncio import httpx from datetime import datetime def handle_private(uid, message): # 處理私聊信息 if message: # 簡單的判斷,只是判斷其是否為空 asyncio.run(send(uid, f"你好呀,請問發(fā)消息給我有什么事情?\n回復(fù)時間:{datetime.now().strftime('%Y-%m-%d %H:%M:%S')}")) async def send(uid, message, gid=None): """ 用于發(fā)送消息的函數(shù) :param uid: 用戶id :param message: 發(fā)送的消息 :param gid: 群id :return: None """ async with httpx.AsyncClient(base_url="http://127.0.0.1:5700") as client: if gid is None: # 如果發(fā)送的為私聊消息 print(uid) params = { "user_id": uid, "message": message, } await client.get("/send_private_msg", params=params)
然后,我們開始運(yùn)行程序:
nohup ./go-cqhttp >> go-cqhttp.log 2>&1 & # 都在后臺運(yùn)行 nohup python ./code/main.py >> message.log 2>&1 & # 在后臺運(yùn)行
同時,還有一種源碼編譯的方法,請大家自行去官網(wǎng)上查看
原文鏈接:https://blog.csdn.net/qq_62789540/article/details/126791009
相關(guān)推薦
- 2022-08-14 Selenium定位瀏覽器彈窗方法實(shí)例總結(jié)_python
- 2022-11-23 一文教會你用正則表達(dá)式校驗(yàn)日期時間格式_正則表達(dá)式
- 2022-04-25 ASP.NET?Core中Razor頁面與MVC區(qū)別介紹_實(shí)用技巧
- 2022-06-18 Elasticsearches通過坐標(biāo)位置實(shí)現(xiàn)對附近人的搜索_其它綜合
- 2022-09-21 Python數(shù)據(jù)庫反向生成Model最優(yōu)方案示例_python
- 2022-04-18 python?如何讀取列表中字典的value值_python
- 2022-05-28 Redis如何使用樂觀鎖(CAS)保證數(shù)據(jù)一致性_Redis
- 2022-10-25 基于Linux服務(wù)器出現(xiàn)“No space left on device”錯誤的解決簡單有效方案
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支