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

下載后,我們得到這么一個(gè)文件:

2、 配置
然后,我們雙擊打開(kāi):

我們直接選擇0,僅使用HTTP通信:
在同級(jí)目錄下,生成了一個(gè)config.yml的配置文件
我們使用記事本打開(kāi)這個(gè)配置文件:

打開(kāi)文件后,我們暫時(shí)只需要修改兩處
第一處,修改第4行和第5行:

第二處,將第108行和第109行的注釋解開(kāi):

其為用來(lái)監(jiān)聽(tīng)消息的路由,后面我們使用flask,開(kāi)啟該路由,來(lái)使得qq的消息可以傳入后臺(tái),使我們可以處理
3、 登錄
再次雙擊我們的exe文件

然后,我們先關(guān)閉該窗口,開(kāi)始編寫我們的程序
4、 監(jiān)聽(tīng)消息
我們先在根目錄上創(chuàng)建一個(gè)code文件夾
再在code文件夾中,創(chuàng)建main.py以及script.py兩個(gè)文件
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):
# 這里對(duì)消息進(jìn)行分發(fā),暫時(shí)先設(shè)置一個(gè)簡(jiǎn)單的分發(fā)
_ = request.json
if _.get("message_type") == "private": # 說(shuō)明有好友發(fā)送信息過(guò)來(lái)
uid = _["sender"]["user_id"] # 獲取發(fā)信息的好友qq號(hào)
message = _["raw_message"] # 獲取發(fā)送過(guò)來(lái)的消息
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: # 簡(jiǎn)單的判斷,只是判斷其是否為空
asyncio.run(send(uid, f"你好呀,請(qǐng)問(wèn)發(fā)消息給我有什么事情?\n回復(fù)時(shí)間:{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)
最后,我們可以測(cè)試一下,如果出現(xiàn)自動(dòng)回復(fù),則說(shuō)明,我們的機(jī)器人配置已經(jīng)基本完成了
三、 Linux 搭建
1、 下載
還是在發(fā)行版頁(yè)面進(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)行解壓縮
解壓縮完成后,我們得到三個(gè)文件

2、 配置
生成配置文件

然后,將我們的配置文件按照Windows上面的配置一樣進(jìn)行修改:
第四行,第五行設(shè)置QQ賬號(hào)和密碼

第108行和第109行的注釋解開(kāi):
使用:108直接定位到第108行

3、 登錄
登錄成功后,關(guān)閉程序
4、 開(kāi)放端口
開(kāi)放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)聽(tīng)消息
我們先在根目錄上創(chuàng)建一個(gè)code文件夾
再在code文件夾中,創(chuàng)建main.py以及script.py兩個(gè)文件
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):
# 這里對(duì)消息進(jìn)行分發(fā),暫時(shí)先設(shè)置一個(gè)簡(jiǎn)單的分發(fā)
_ = request.json
if _.get("message_type") == "private": # 說(shuō)明有好友發(fā)送信息過(guò)來(lái)
uid = _["sender"]["user_id"] # 獲取發(fā)信息的好友qq號(hào)
message = _["raw_message"] # 獲取發(fā)送過(guò)來(lái)的消息
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: # 簡(jiǎn)單的判斷,只是判斷其是否為空
asyncio.run(send(uid, f"你好呀,請(qǐng)問(wèn)發(fā)消息給我有什么事情?\n回復(fù)時(shí)間:{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)
然后,我們開(kāi)始運(yùn)行程序:
nohup ./go-cqhttp >> go-cqhttp.log 2>&1 & # 都在后臺(tái)運(yùn)行 nohup python ./code/main.py >> message.log 2>&1 & # 在后臺(tái)運(yùn)行
同時(shí),還有一種源碼編譯的方法,請(qǐng)大家自行去官網(wǎng)上查看
到此這篇關(guān)于go-cqhttp環(huán)境配置的文章就介紹到這了,更多相關(guān)go-cqhttp環(huán)境配置內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Golang內(nèi)存泄漏場(chǎng)景以及解決方案詳析
golang中內(nèi)存泄露的發(fā)現(xiàn)與排查一直是來(lái)是go開(kāi)發(fā)者頭疼的一件事,下面這篇文章主要給大家介紹了關(guān)于Golang內(nèi)存泄漏場(chǎng)景以及解決的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-01-01
go build -tags構(gòu)建約束試驗(yàn)示例解析
這篇文章主要為大家介紹了go build -tags構(gòu)建約束試驗(yàn)示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-09-09
一文搞懂Golang文件操作增刪改查功能(基礎(chǔ)篇)
這篇文章主要介紹了一文搞懂Golang文件操作增刪改查功能(基礎(chǔ)篇),Golang 可以認(rèn)為是服務(wù)器開(kāi)發(fā)語(yǔ)言發(fā)展的趨勢(shì)之一,特別是在流媒體服務(wù)器開(kāi)發(fā)中,已經(jīng)占有一席之地,今天我們不聊特別深?yuàn)W的機(jī)制和內(nèi)容,就來(lái)聊一聊 Golang 對(duì)于文件的基本操作2021-04-04
go語(yǔ)言日志記錄庫(kù)簡(jiǎn)單使用方法實(shí)例分析
這篇文章主要介紹了go語(yǔ)言日志記錄庫(kù)簡(jiǎn)單使用方法,實(shí)例分析了Go語(yǔ)言日志記錄的操作的技巧,需要的朋友可以參考下2015-03-03
golang分層測(cè)試之http接口測(cè)試入門教程
這篇文章主要介紹了golang分層測(cè)試之http接口測(cè)試入門教程,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-12-12

