go-cqhttp環(huán)境配置及安裝過程
go-cqhttp安裝
一、 簡介
1、 介紹
官方文檔地址:https://docs.go-cqhttp.org/
各種框架都只是機器人的各種實現(xiàn),每個框架之間接口都不通用,編程語言也不盡相同,想要開發(fā)一個自己的機器人,換一套框架所有的代碼都要推到重來,所以亟需一個規(guī)范統(tǒng)一各個框架,所以O(shè)neBot 誕生了,先來看看OneBot 是啥:
OneBot 標(biāo)準(zhǔn):
一個聊天機器人應(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)用機器人接口實現(xiàn)自己的邏輯,而且基于CQHTTP 已經(jīng)實現(xiàn)了很多功能的機器人了,詳情見上面優(yōu)秀機器人框架,為了不讓以前所有的優(yōu)秀代碼都要推倒重來,所以O(shè)neBot 干脆直接在CQHTTP 的基礎(chǔ)之上指定標(biāo)準(zhǔn),這就是典型的先有實現(xiàn),后有標(biāo)準(zhǔn)的例子。
在這個標(biāo)準(zhǔn)的基礎(chǔ)之上,有了各種編程語言的實現(xiàn),我們稱之為生態(tài),如下:
理論上,基于 OneBot 標(biāo)準(zhǔn)開發(fā)的任何 SDK、框架和機器人應(yīng)用,都可以無縫地在下面的不同實現(xiàn)中切換。當(dāng)然,在一小部分細(xì)節(jié)上各實現(xiàn)可能有一些不同,這也是本項目希望推動解決的問題。
MiraiGo就是GO語言實現(xiàn)的安卓QQ協(xié)議,API很原始,相當(dāng)于一個類庫,go-cqhttp是在MiraiGo的基礎(chǔ)之上封裝的HTTP協(xié)議和Websocket協(xié)議接口的框架,得益于GO語言先天的優(yōu)勢(資源占用少,運行簡單,協(xié)程并發(fā)高),總之就是性能高,引用項目原話 :
性能體現(xiàn):
- 在關(guān)閉數(shù)據(jù)庫的情況下, 加載 25 個好友 128 個群運行 24 小時后內(nèi)存使用為 10MB 左右. 開啟數(shù)據(jù)庫后內(nèi)存使用將根據(jù)消息量增加 10-20MB, 如果系統(tǒng)內(nèi)存小于 128M 建議關(guān)閉數(shù)據(jù)庫使用. 2、 優(yōu)點
接口:
- HTTP API
- 反向HTTP POST
- 正向WebSocket
- 反向WebSocket
拓展支持:
- HTTP POST多點上報
- 反向WS多點連接
- 修改群名
- 消息撤回事件
- 解析/發(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í)行文件,然后進行下載:

下載后,我們得到這么一個文件:

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):
# 這里對消息進行分發(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īng)基本完成了
三、 Linux 搭建
1、 下載
還是在發(fā)行版頁面進行下載:https://github.com/Mrs4s/go-cqhttp/releases
根據(jù)版本選擇我們需要的壓縮包,然后進行下載:

下載的命令:
mkdir bot # 創(chuàng)建bot目錄 cd bot # 進入目錄中 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 # 然后進行解壓縮
解壓縮完成后,我們得到三個文件

2、 配置
生成配置文件

然后,將我們的配置文件按照Windows上面的配置一樣進行修改:
第四行,第五行設(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):
# 這里對消息進行分發(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)
然后,我們開始運行程序:
nohup ./go-cqhttp >> go-cqhttp.log 2>&1 & # 都在后臺運行 nohup python ./code/main.py >> message.log 2>&1 & # 在后臺運行
同時,還有一種源碼編譯的方法,請大家自行去官網(wǎng)上查看
到此這篇關(guān)于go-cqhttp環(huán)境配置的文章就介紹到這了,更多相關(guān)go-cqhttp環(huán)境配置內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
GoLang日志監(jiān)控系統(tǒng)實現(xiàn)
這篇文章主要介紹了GoLang日志監(jiān)控系統(tǒng)的實現(xiàn)流程,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧2022-12-12
Go內(nèi)存節(jié)省技巧簡單實現(xiàn)方法
這篇文章主要為大家介紹了Go內(nèi)存節(jié)省技巧簡單實現(xiàn)方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-01-01
如何在golang中使用shopspring/decimal來處理精度問題
本文主要介紹了如何在golang中使用shopspring/decimal來處理精度問題,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-04-04
Go中基本數(shù)據(jù)類型和字符串表示之間轉(zhuǎn)換詳解
這篇文章主要為大家詳細(xì)介紹了Go中基本數(shù)據(jù)類型和字符串表示之間轉(zhuǎn)換的相關(guān)知識,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-01-01

