首頁 > 軟體

go-cqhttp環境設定及安裝過程

2022-09-12 18:01:09

go-cqhttp安裝

一、 簡介

1、 介紹

官方檔案地址:https://docs.go-cqhttp.org/

各種框架都只是機器人的各種實現,每個框架之間介面都不通用,程式語言也不盡相同,想要開發一個自己的機器人,換一套框架所有的程式碼都要推到重來,所以亟需一個規範統一各個框架,所以OneBot 誕生了,先來看看OneBot 是啥:

OneBot 標準

一個聊天機器人應用介面標準

簡單

介面簡單易懂,可輕鬆接入。

相容性

相容原 CQHTTP 外掛,零負擔遷移。

相容原 CQHTTP 外掛,這個標準和CQHTTP有啥關係?CQHTTP是酷Q的一個外掛,這個外掛可以提供HTTP協定的介面供第三方系統呼叫,這樣就和具體語言無關,什麼語言都可以呼叫機器人介面實現自己的邏輯,而且基於CQHTTP 已經實現了很多功能的機器人了,詳情見上面優秀機器人框架,為了不讓以前所有的優秀程式碼都要推倒重來,所以OneBot 乾脆直接在CQHTTP 的基礎之上指定標準,這就是典型的先有實現,後有標準的例子。

在這個標準的基礎之上,有了各種程式語言的實現,我們稱之為生態,如下:

理論上,基於 OneBot 標準開發的任何 SDK、框架和機器人應用,都可以無縫地在下面的不同實現中切換。當然,在一小部分細節上各實現可能有一些不同,這也是本專案希望推動解決的問題。

MiraiGo就是GO語言實現的安卓QQ協定,API很原始,相當於一個類庫,go-cqhttp是在MiraiGo的基礎之上封裝的HTTP協定和Websocket協定介面的框架,得益於GO語言先天的優勢(資源佔用少,執行簡單,協程並行高),總之就是效能高,參照專案原話 :

效能體現:

  • 在關閉資料庫的情況下, 載入 25 個好友 128 個群執行 24 小時後記憶體使用為 10MB 左右. 開啟資料庫後記憶體使用將根據訊息量增加 10-20MB, 如果系統記憶體小於 128M 建議關閉資料庫使用. 2、 優點

介面:

  • HTTP API
  • 反向HTTP POST
  • 正向WebSocket
  • 反向WebSocket

拓展支援:

  • HTTP POST多點上報
  • 反向WS多點連線
  • 修改群名
  • 訊息撤回事件
  • 解析/傳送 回覆訊息
  • 解析/傳送 合併轉發
  • 使用代理請求網路圖片

搭建的檔案地址:https://docs.go-cqhttp.org/guide/quick_start.html

二、 Windows 搭建

1、 下載

在發行版中:https://github.com/Mrs4s/go-cqhttp/releases

找到屬於自己系統的可執行檔案,然後進行下載:

下載後,我們得到這麼一個檔案:

2、 設定

然後,我們雙擊開啟:

我們直接選擇0,僅使用HTTP通訊:

在同級目錄下,生成了一個config.yml的組態檔

我們使用記事本開啟這個組態檔:

開啟檔案後,我們暫時只需要修改兩處

第一處,修改第4行和第5行:

第二處,將第108行和第109行的註釋解開:

其為用來監聽訊息的路由,後面我們使用flask,開啟該路由,來使得qq的訊息可以傳入後臺,使我們可以處理

3、 登入

再次雙擊我們的exe檔案

然後,我們先關閉該視窗,開始編寫我們的程式

4、 監聽訊息

我們先在根目錄上建立一個code資料夾

再在code資料夾中,建立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):
        # 這裡對訊息進行分發,暫時先設定一個簡單的分發
        _ = request.json
        if _.get("message_type") == "private":  # 說明有好友傳送資訊過來
            uid = _["sender"]["user_id"]  # 獲取發資訊的好友qq號
            message = _["raw_message"]  # 獲取傳送過來的訊息
            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"你好呀,請問發訊息給我有什麼事情?n回覆時間:{datetime.now().strftime('%Y-%m-%d %H:%M:%S')}"))
async def send(uid, message, gid=None):
    """
    用於傳送訊息的函數
    :param uid: 使用者id
    :param message: 傳送的訊息
    :param gid: 群id
    :return: None
    """
    async with httpx.AsyncClient(base_url="http://127.0.0.1:5700") as client:
        if gid is None:
            # 如果傳送的為私聊訊息
            print(uid)
            params = {
                "user_id": uid,
                "message": message,
            }
        await client.get("/send_private_msg", params=params)

最後,我們可以測試一下,如果出現自動回覆,則說明,我們的機器人設定已經基本完成了

三、 Linux 搭建

1、 下載

還是在發行版頁面進行下載:https://github.com/Mrs4s/go-cqhttp/releases

根據版本選擇我們需要的壓縮包,然後進行下載:

下載的命令:

mkdir bot  # 建立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上面的設定一樣進行修改:

第四行,第五行設定QQ賬號和密碼

第108行和第109行的註釋解開:

使用:108直接定位到第108行

3、 登入

登入成功後,關閉程式

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、 監聽訊息

我們先在根目錄上建立一個code資料夾

再在code資料夾中,建立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):
        # 這裡對訊息進行分發,暫時先設定一個簡單的分發
        _ = request.json
        if _.get("message_type") == "private":  # 說明有好友傳送資訊過來
            uid = _["sender"]["user_id"]  # 獲取發資訊的好友qq號
            message = _["raw_message"]  # 獲取傳送過來的訊息
            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"你好呀,請問發訊息給我有什麼事情?n回覆時間:{datetime.now().strftime('%Y-%m-%d %H:%M:%S')}"))

async def send(uid, message, gid=None):
    """
    用於傳送訊息的函數
    :param uid: 使用者id
    :param message: 傳送的訊息
    :param gid: 群id
    :return: None
    """
    async with httpx.AsyncClient(base_url="http://127.0.0.1:5700") as client:
        if gid is None:
            # 如果傳送的為私聊訊息
            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 &  # 在後臺執行

同時,還有一種原始碼編譯的方法,請大家自行去官網上檢視

到此這篇關於go-cqhttp環境設定的文章就介紹到這了,更多相關go-cqhttp環境設定內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com