飞书上传插件:自动化文件共享与消息发送 - Openclaw Skills

作者:互联网

2026-03-30

AI教程

什么是 飞书上传插件?

飞书上传插件是专为连接本地文件系统与飞书(Lark)协作平台而设计的集成工具。该工具专为 Openclaw Skills 用户打造,通过自动化手段替代繁琐的手动文件传输和消息编辑过程。它利用 Node.js 18+ 的原生功能(包括 fetch API 和 FormData),在无需繁重外部依赖的情况下确保轻量化运行。

对于需要以编程方式分发构建日志、每日报告或媒体文件的开发人员和团队而言,此插件至关重要。它简化了从身份验证到交付的整个工作流程,成为飞书生态系统中任何需要可靠文档分发的办公自动化流程的基石。

下载入口:https://github.com/openclaw/skills/tree/main/skills/deewooo/feishu-upload-skill

安装与下载

1. ClawHub CLI

从源直接安装技能的最快方式。

npx clawhub@latest install feishu-upload-skill

2. 手动安装

将技能文件夹复制到以下位置之一

全局模式 ~/.openclaw/skills/ 工作区 /skills/

优先级:工作区 > 本地 > 内置

3. 提示词安装

将此提示词复制到 OpenClaw 即可自动安装。

请帮我使用 Clawhub 安装 feishu-upload-skill。如果尚未安装 Clawhub,请先安装(npm i -g clawhub)。

飞书上传插件 应用场景

  • 自动化将每日数据分析报告发送至指定的飞书群聊。
  • 通过编程方式将 CI/CD 流水线的构建产物或错误日志直接共享到开发频道。
  • 在自动化 UI 测试流程中即时分发截图或媒体资源。
  • 方便地将本地环境的文档自动备份到飞书云文档,供团队访问。
飞书上传插件 工作原理
  1. 插件使用 App ID 和 Secret 向飞书 API 发起身份验证请求,获取有效的租户访问令牌。
  2. 执行本地文件检查,确保资产符合飞书即时通讯(IM)上传 30MB 的强制限制。
  3. 文件被上传至 /im/v1/files 接口,成功后返回唯一的 file_key。
  4. 使用生成的文件密钥,通过飞书消息 API 向指定的聊天 ID 发送结构化消息。
  5. 访问令牌会自动在本地缓存,以减少 API 调用并提高后续操作的性能。

飞书上传插件 配置指南

要将此功能集成到现有的 Openclaw Skills 中,请确保已安装 Node.js 18+。配置您的飞书应用凭据并运行以下命令:

# 将插件克隆到项目中
cp -r feishu-upload-skill skills/

# 初始化访问令牌
./get_feishu_token.sh

# 上传文件并发送至聊天
node feishu_complete_upload.js <文件路径> <聊天ID>

飞书上传插件 数据架构与分类体系

该插件通过简单的文件系统管理其状态和元数据,以确保高可靠性和低延迟:

文件名 描述
feishu_token.txt 缓存租户访问令牌,防止冗余的身份验证请求。
upload_result.json 存储上次上传的响应,包括 file_key 和时间戳。
feishu_complete_upload.js 处理端到端上传和消息逻辑的主执行脚本。

Feishu Upload Skill

飞书文件上传技能 - 直接上传文件到飞书并发送到聊天

功能特性

? 文件上传:上传本地文件到飞书云盘 ? 消息发送:发送文件消息到指定聊天 ? 自动令牌管理:自动获取和刷新访问令牌 ? 大小限制检查:自动检查30MB文件大小限制 ? 多格式支持:支持各种文件类型(文本、图片、压缩包等) ? 纯Node.js实现:无需额外依赖,使用Node.js 18+原生功能

快速开始

1. 上传文件并发送到聊天

node feishu_complete_upload.js <文件路径> <聊天ID>

示例:

node feishu_complete_upload.js document.txt oc_dd899cb1a7846915cdd2d6850bd1dafa

2. 仅上传文件(获取文件Key)

node feishu_complete_upload.js <文件路径>

3. 使用简化脚本

# 简单上传
node native_feishu_upload.js <文件路径>

# 获取访问令牌
./get_feishu_token.sh

文件说明

核心文件

  • feishu_complete_upload.js - 完整的上传和发送工具(推荐)
  • native_feishu_upload.js - 使用原生FormData的简单上传工具
  • get_feishu_token.sh - 获取和刷新访问令牌的脚本

辅助文件

  • feishu_upload_simple.sh - Bash实现的简单上传脚本
  • feishu_upload_fixed.sh - 修复版Bash上传脚本
  • simple_feishu_upload.js - 简化版Node.js上传工具

配置文件

  • feishu_token.txt - 访问令牌缓存文件(自动生成)
  • upload_result.json - 上次上传的结果文件

技术原理

三步上传流程

  1. 获取访问令牌:使用App ID和Secret获取tenant_access_token
  2. 上传文件:使用飞书/im/v1/files API上传文件,获取file_key
  3. 发送消息:使用file_key发送文件消息到指定聊天

API端点

  • 获取令牌:POST /open-apis/auth/v3/tenant_access_token/internal
  • 上传文件:POST /open-apis/im/v1/files
  • 发送消息:POST /open-apis/im/v1/messages

权限要求

  • im:message:send_as_bot - 发送消息权限
  • im:file:send_as_bot - 发送文件权限(可能需要)
  • 文件上传权限(通过drive:file:upload已授权)

使用示例

示例1:上传文本文件

# 创建测试文件
echo "测试内容" > test.txt

# 上传并发送到群聊
node feishu_complete_upload.js test.txt oc_dd899cb1a7846915cdd2d6850bd1dafa

示例2:上传图片文件

# 上传图片
node feishu_complete_upload.js photo.jpg oc_dd899cb1a7846915cdd2d6850bd1dafa

示例3:上传压缩包

# 压缩文件
tar -czf archive.tar.gz folder/

# 上传压缩包
node feishu_complete_upload.js archive.tar.gz oc_dd899cb1a7846915cdd2d6850bd1dafa

错误处理

常见错误

  1. 令牌过期:自动刷新令牌
  2. 文件太大:超过30MB限制
  3. 权限不足:检查飞书应用权限配置
  4. 网络问题:自动重试机制

调试模式

# 查看详细日志
DEBUG=1 node feishu_complete_upload.js file.txt chat_id

集成到OpenClaw

作为工具调用

const { execSync } = require('child_process');
const result = execSync('node feishu_complete_upload.js file.txt chat_id').toString();
console.log(JSON.parse(result));

作为Skill使用

  1. 将此文件夹复制到skills/目录
  2. 在OpenClaw配置中启用
  3. 通过命令或API调用

注意事项

  1. 文件大小:最大支持30MB文件
  2. 令牌有效期:访问令牌2小时有效,自动刷新
  3. 权限配置:确保飞书应用有正确的权限
  4. 网络环境:需要能访问飞书API的网络环境
  5. Node.js版本:需要Node.js 18+(支持全局FormData和fetch)

更新日志

v1.0.0 (2026-02-12)

  • ? 初始版本发布
  • ? 完整的文件上传和发送功能
  • ? 自动令牌管理
  • ? 错误处理和日志
  • ? 多文件格式支持

许可证

MIT License - 自由使用和修改