Skip to content

💖 NapCatのWebUI配置指南💖

字数
1397 字
阅读时间
6 分钟

WARNING

低于 4.4.7 请勿将注释内容写入配置文件, 否则会导致配置文件解析失败, 新版本不受限制.

配置网络类型 必备知识

类型描述
HTTP 服务端NapCat 作为 Http 请求接受方 接收对应接口调用并回应 的单工模型
HTTP 客户端NapCat 作为 Http 请求发起方 将事件推送至插件/应用框架 的单工模型
WebSocket 服务端通常指正向 WS 既能主动推送事件也能接收请求 的双工模型
WebSocket 客户端通常指反向 WS 既能主动推送事件也能接收请求 的双工模型

通过 WebUI 配置 OneBot 服务 Shell Vesion

如果你已经启动了 NapCat, 并且有多于 1 个开放端口,则可以通过 WebUI 进行配置.

默认地址为 0.0.0.0, 即监听所有地址. 当配置了不可用的地址时 WebUI 将被禁用.

默认端口为 6099.

当端口被设置为 0 时将禁用 WebUI.

当端口被占用时, 会自动对端口 +1, 直到找到可用端口 (最多尝试 100 次, 失败则会禁用 WebUI), 端口号会在启动日志中显示.

启动后可在启动日志中看到形如 [WebUi] WebUi Local Panel Url: http://127.0.0.1:6099/webui?token=xxxx 的 token 信息.

也可打开 webui.json 文件,在其中找到token。(使用 NapCat.Installer - Linux 一键脚本安装时, 该文件位于 /opt/QQ/resources/app/app_launcher/napcat/config/webui.json)

json5
{
    "host": "0.0.0.0", // WebUI 监听地址
    "port": 6099, // WebUI 端口
    "token": "xxxx", // 登录密钥, 默认是自动生成的随机登录密码
    "loginRate": 3, // 每分钟登录次数限制
}

访问 http://ip:port/webui/,然后进行以下操作:

  1. 进入 QQ 登录, 点击 QRCode 进行二维码登录.

  2. 登录成功后, 即可进入网络配置, 点击 "新建" 创建对应的服务器或客户端.(如果是公网部署, 请务必启用 Token)

  3. 请在创建时勾选保存时启用, 或者创建完成后手动启用.

  4. 访问 http://ip:port 检查端口是否正常. (此处的 port 指 2 中配置的端口, 请不要与 WebUI 端口混淆)

注:WebUI 自 v4.4 版本后不支持 prefix 配置.

通过 TUI-CLI 配置 OneBot 服务 Shell Vesion

前置条件,使用Shell安装时同意安装TUI-CLI或者使用--cli y参数详见Shell安装 recommend)

只需要你在终端中输入 sudo napcat 即可进入 TUI-CLI 界面.

通过 文件 配置OneBot服务 Any Vesion

非常不推荐 除非你非常熟悉

v4.5.3 后支持载入 ./config/onebot11.json 作为默认配置

该配置文件名为 ./config/onebot11_xxxx.json 其中xxxx为对应QQ账户

json5
{
  "network": {
    // Http服务器组 可以配置多个 这里演示为一个
    "httpServers": [
      {
        "name": "httpServer",// 名字不能重复 唯一标识
        "enable": false,//启用状态
        "port": 3000,// 监听端口
        "host": "0.0.0.0",// 监听主机
        "enableCors": true,// 暂时没有作用
        "enableWebsocket": true,// 暂时没有作用
        "messagePostFormat": "array",// 消息上报格式 string/array
        "token": "",// 鉴权密钥
        "debug": false,// raw数据上报
      }
    ],
    "httpClients": [],
    "websocketServers": [],
    "websocketClients": []
  },
  "musicSignUrl": "",
  "enableLocalFile2Url": false,
  "parseMultMsg": false
}
json5
{
  "network": {
    "httpServers": [],
    // Http客户端组 可以配置多个 这里演示为一个
    "httpClients": [
       {
        "name": "httpClient",// 名字不能重复 唯一标识
        "enable": false,//启用状态
        "url": "http://localhost:8080",// 上报地址
        "messagePostFormat": "array",// 消息上报格式 string/array
        "reportSelfMessage": false,// 是否上报自身消息
        "token": "",// 鉴权密钥
        "debug": false,// raw数据上报
      }
    ],
    "websocketServers": [],
    "websocketClients": []
  },
  "musicSignUrl": "",
  "enableLocalFile2Url": false,
  "parseMultMsg": false
}
json5
{
  "network": {
    "httpServers": [],
    "httpClients": [],
    // WS服务端组/正向WS  可以配置多个 这里演示为一个
    "websocketServers": [
      {
        "name": "WsServer",// 名字不能重复 唯一标识
        "enable": false,//启用状态
        "host": "0.0.0.0",// 监听主机
        "port": 3001,// 监听端口
        "messagePostFormat": "array",// 消息上报格式 string/array
        "reportSelfMessage": false,// 是否上报自身消息
        "token": "",// 鉴权密钥
        "enableForcePushEvent": true,// 暂时没有作用
        "debug": false,// raw数据上报
        "heartInterval": 30000,// 心跳周期
      }
    ],
    "websocketClients": []
  },
  "musicSignUrl": "",
  "enableLocalFile2Url": false,
  "parseMultMsg": false
}
json5
{
  "network": {
    "httpServers": [],
    "httpClients": [],
    "websocketServers": [],
    // WS客户端组/反向WS 可以配置多个 这里演示为一个
    "websocketClients": [
      {
        "name": "WsClient",// 名字不能重复 唯一标识
        "enable": false,//启用状态
        "url": "ws://localhost:8082",// 上报地址
        "messagePostFormat": "array",// 消息上报格式 string/array
        "reportSelfMessage": false,// 是否上报自身消息
        "reconnectInterval": 5000,// 重连间隔
        "token": "",// 鉴权密钥
        "debug": false,// raw数据上报
        "heartInterval": 30000,// 心跳周期
      }
    ]
  },
  "musicSignUrl": "",
  "enableLocalFile2Url": false,
  "parseMultMsg": false
}

配置 NapCat 其它设置

如果不懂干嘛,不用看啦 在这里你可以修改日志等基础设置

v4.5.3 后支持载入 ./config/napcat.json作为默认配置

启动登录 NapCat 后,打开 NapCat 的 config 目录,找到名为 napcat_<你的QQ号>.json 的文件,如 napcat_1234567.json

配置内容参数解释:

json5
{
  // 是否开启文件日志
  "fileLog": true,
  // 是否开启控制台日志
  "consoleLog": true,
  // 日志等级, 可选值: debug, info, error
  "fileLogLevel": "debug",
  "consoleLogLevel": "info",
  "packetServer":""
}