Skip to content

NapCat 推荐框架最佳实践

字数
765 字
阅读时间
3 分钟

关于大文件/Docker/跨设备部署考虑下的框架设计

发送文件:

至少启动一个 HTTP 端口(可以和 WebSocket 服务端复用端口),并采用此端口在需要文件时通过 URL 传递文件。

接收文件:

  • 大部分文件提供了 URL 上报
  • 没有 URL 时应该通过 get_file 获取本地文件
  • 注意:音频给出的 URL 是 raw silk 格式未处理
  • 非视频 图片 音频的普通文件的链接下载次数影响,可通过下面接口再次获取直链

通常方法获取直链和文件下载

获取文件直链 (Raw)

通过以下端点获取文件直链:

  • 群聊文件/get_group_file_url

    • 参数:
      file_id     字符串   必须
      group       字符串   必须
  • 私聊文件/get_private_file_url

    • 参数:
      file_id     字符串   必须

下载到本地或者输出base64 (Raw)

通过以下端点获取文件:

  • 文件下载/get_file
    • 参数:
      file_id     字符串   可选(file_id 或 file 任意一个用于标记文件获取)
      file        字符串   可选(file_id 或 file 任意一个用于标记唯一文件获取)

File: 音频文件的处理

重点问题

在接收音频时,NapCat 通常需要将音视频文件以本地文件的形式传递,无法直接提供 URL。这是因为:

  • NTQQ 内部只能调用下载接口到本地,不能获取 URL(NapCat 虽然有能力获取,但存在新问题)
  • 腾讯的音频文件为 silk 格式,必须使用 silk 和本地 ffmpeg 转码才能通用
  • 在发送时也需要 silk 进行编码

NapCat设计

  • 接收时:接口请求后,NapCat 下载到本地,可选内置 silk/ffmpeg 进行转码,提供给外部 mp3 等通用格式
  • 发送时:接口请求后,NapCat 下载到本地,内置 silk/ffmpeg 进行转码 silk 后并进行发送

如何获取音频文件

通过以下端点获取音频文件:

  • 音频文件获取/get_record
    • 参数:
      file_id     字符串   可选(file_id 或 file 任意一个用于标记文件获取)
      file        字符串   可选(file_id 或 file 任意一个用于标记唯一文件获取)
      out_format  字符串   可选(mp3, amr, wma, m4a, spx, ogg, wav, flac)

如何发送音频文件

通过通常的方法发送音频文件,无需特别注意。

File: 视频文件的处理

提示

视频文件最大 100MB,超过此大小请通过群文件方式发送。

File: 图片文件的处理

提示

图片的链接具有约 2 小时的过期时间,当过期后会提示 url expired

此时可以调用 nc_get_rkey 获取新 rkey 替换 rkey 使用,或者通过 get_imageget_fileget_msg 刷新获取新的 URL。