feishu-card
飞书交互卡片。构建和发送带按钮/选择器的消息卡片。
下記のコマンドをコピーしてターミナル(Mac/Linux)または PowerShell(Windows)に貼り付けてください。 ダウンロード → 解凍 → 配置まで全自動。
mkdir -p ~/.claude/skills && cd ~/.claude/skills && curl -L -o feishu-card.zip https://jpskill.com/download/21598.zip && unzip -o feishu-card.zip && rm feishu-card.zip
$d = "$env:USERPROFILE\.claude\skills"; ni -Force -ItemType Directory $d | Out-Null; iwr https://jpskill.com/download/21598.zip -OutFile "$d\feishu-card.zip"; Expand-Archive "$d\feishu-card.zip" -DestinationPath $d -Force; ri "$d\feishu-card.zip"
完了後、Claude Code を再起動 → 普通に「動画プロンプト作って」のように話しかけるだけで自動発動します。
💾 手動でダウンロードしたい(コマンドが難しい人向け)
- 1. 下の青いボタンを押して
feishu-card.zipをダウンロード - 2. ZIPファイルをダブルクリックで解凍 →
feishu-cardフォルダができる - 3. そのフォルダを
C:\Users\あなたの名前\.claude\skills\(Win)または~/.claude/skills/(Mac)へ移動 - 4. Claude Code を再起動
⚠️ ダウンロード・利用は自己責任でお願いします。当サイトは内容・動作・安全性について責任を負いません。
🎯 このSkillでできること
下記の説明文を読むと、このSkillがあなたに何をしてくれるかが分かります。Claudeにこの分野の依頼をすると、自動で発動します。
📦 インストール方法 (3ステップ)
- 1. 上の「ダウンロード」ボタンを押して .skill ファイルを取得
- 2. ファイル名の拡張子を .skill から .zip に変えて展開(macは自動展開可)
- 3. 展開してできたフォルダを、ホームフォルダの
.claude/skills/に置く- · macOS / Linux:
~/.claude/skills/ - · Windows:
%USERPROFILE%\.claude\skills\
- · macOS / Linux:
Claude Code を再起動すれば完了。「このSkillを使って…」と話しかけなくても、関連する依頼で自動的に呼び出されます。
詳しい使い方ガイドを見る →- 最終更新
- 2026-05-18
- 取得日時
- 2026-05-18
- 同梱ファイル
- 4
📖 Skill本文(日本語訳)
※ 原文(英語/中国語)を Gemini で日本語化したものです。Claude 自身は原文を読みます。誤訳がある場合は原文をご確認ください。
飛書インタラクティブカード
飛書インタラクティブカードを構築、送信、処理します。
ベース URL: https://open.feishu.cn/open-apis/im/v1
使用シナリオ: 朝礼確認、アラート処理、タスク確認、ステータス更新
認証とトークン取得
feishu_skills のルートディレクトリから共有スクリプトを実行します。
TOKEN="$(./scripts/get_feishu_token.sh)"
リクエストヘッダーはすべて Authorization: Bearer ${TOKEN} を使用します。
ビジネスインターフェースがトークン無効、期限切れ、または 401 を返した場合、強制的に更新した後、元のリクエストを一度だけ再試行します。
TOKEN="$(./scripts/get_feishu_token.sh --force-refresh)"
環境変数:
FEISHU_APP_IDFEISHU_APP_SECRET
ローカルキャッシュ: ./.feishu_token_cache.json(期限切れでなければ直接再利用、デフォルトでは5分前に更新)
カードの送信
POST /open-apis/im/v1/messages?receive_id_type=chat_id
{
"receive_id": "<chat_id>",
"msg_type": "interactive",
"content": "<card_json_string>"
}
⚠️ content は文字列化された JSON である必要があります。
カード構造
{
"config": {"wide_screen_mode": true},
"header": {
"title": {"tag": "plain_text", "content": "タイトル"},
"template": "blue"
},
"elements": [
{"tag": "div", "text": {"tag": "lark_md", "content": "**太字**"}},
{"tag": "action", "actions": [
{"tag": "button", "text": {"tag": "plain_text", "content": "確認"}, "type": "primary", "value": {"action": "confirm"}}
]}
]
}
常用要素
| 要素 | 説明 | 示例 |
|---|---|---|
div |
テキストブロック | {"tag":"div","text":{"tag":"lark_md","content":"テキスト"}} |
hr |
区切り線 | {"tag":"hr"} |
action |
ボタン群 | 下記参照 |
note |
備考 | {"tag":"note","elements":[{"tag":"plain_text","content":"備考"}]} |
ボタン
{
"tag": "action",
"actions": [
{
"tag": "button",
"text": {"tag": "plain_text", "content": "確認"},
"type": "primary",
"value": {"action": "confirm", "data": "extra_info"}
}
]
}
ボタンタイプ: default / primary / danger
セレクター
{
"tag": "select_static",
"placeholder": {"tag": "plain_text", "content": "選択してください"},
"options": [
{"text": {"tag": "plain_text", "content": "オプション1"}, "value": "opt1"},
{"text": {"tag": "plain_text", "content": "オプション2"}, "value": "opt2"}
],
"value": {"key": "select_result"}
}
コールバック処理
ユーザーがボタンをクリックすると、飛書は WebSocket イベントを送信します。
{
"type": "card.action.trigger",
"action": {
"value": {"action": "confirm", "data": "extra_info"}
}
}
コールバックを処理した後、カードを更新できます。
PATCH /open-apis/im/v1/messages/{message_id}
ベストプラクティス
- ボタンに value を持たせる(コールバック識別用)
- 新しいメッセージの代わりにカードを更新する(画面の乱雑さを減らす)
- 危険な操作には danger タイプを使用する
📜 原文 SKILL.md(Claudeが読む英語/中国語)を展開
飞书交互卡片
构建、发送和处理飞书交互卡片。
Base URL: https://open.feishu.cn/open-apis/im/v1
使用场景: 晨报确认、告警处理、任务确认、状态更新
认证与 Token 获取
从 feishu_skills 根目录执行共享脚本:
TOKEN="$(./scripts/get_feishu_token.sh)"
请求头统一使用 Authorization: Bearer ${TOKEN}。
如果业务接口返回 token 无效、过期或 401,强制刷新后仅重试一次原请求:
TOKEN="$(./scripts/get_feishu_token.sh --force-refresh)"
环境变量:
FEISHU_APP_IDFEISHU_APP_SECRET
本地缓存: ./.feishu_token_cache.json(未过期直接复用,默认提前 5 分钟刷新)
发送卡片
POST /open-apis/im/v1/messages?receive_id_type=chat_id
{
"receive_id": "<chat_id>",
"msg_type": "interactive",
"content": "<card_json_string>"
}
⚠️ content 必须是字符串化的 JSON。
卡片结构
{
"config": {"wide_screen_mode": true},
"header": {
"title": {"tag": "plain_text", "content": "标题"},
"template": "blue"
},
"elements": [
{"tag": "div", "text": {"tag": "lark_md", "content": "**加粗**"}},
{"tag": "action", "actions": [
{"tag": "button", "text": {"tag": "plain_text", "content": "确认"}, "type": "primary", "value": {"action": "confirm"}}
]}
]
}
常用元素
| 元素 | 说明 | 示例 |
|---|---|---|
div |
文本块 | {"tag":"div","text":{"tag":"lark_md","content":"文本"}} |
hr |
分割线 | {"tag":"hr"} |
action |
按钮组 | 见下方 |
note |
备注 | {"tag":"note","elements":[{"tag":"plain_text","content":"备注"}]} |
按钮
{
"tag": "action",
"actions": [
{
"tag": "button",
"text": {"tag": "plain_text", "content": "确认"},
"type": "primary",
"value": {"action": "confirm", "data": "extra_info"}
}
]
}
按钮类型: default / primary / danger
选择器
{
"tag": "select_static",
"placeholder": {"tag": "plain_text", "content": "请选择"},
"options": [
{"text": {"tag": "plain_text", "content": "选项1"}, "value": "opt1"},
{"text": {"tag": "plain_text", "content": "选项2"}, "value": "opt2"}
],
"value": {"key": "select_result"}
}
回调处理
用户点击按钮后,飞书会发送 WebSocket 事件:
{
"type": "card.action.trigger",
"action": {
"value": {"action": "confirm", "data": "extra_info"}
}
}
处理回调后可更新卡片:
PATCH /open-apis/im/v1/messages/{message_id}
最佳实践
- 按钮带 value(用于回调识别)
- 卡片更新代替新消息(减少刷屏)
- 危险操作用 danger 类型
同梱ファイル
※ ZIPに含まれるファイル一覧。`SKILL.md` 本体に加え、参考資料・サンプル・スクリプトが入っている場合があります。
- 📄 SKILL.md (2,943 bytes)
- 📎 references/card-alert.json (1,136 bytes)
- 📎 references/card-morning-briefing.json (1,419 bytes)
- 📎 references/card-skill-test.json (1,154 bytes)