Install
openclaw skills install @qingmuhuijianghu/skill-matrix-publisher-free一键将免费Skill分发到腾讯SkillHub(个人版+团队版)、虾聊、虾友SkillHub、GitHub、ClawHub六大平台 v3.7.0 支持版本更新 + 双通道安装 + 编码乱码修复 + 智能违规自动修复 + 品牌署名铁律 + 发布后isFree强校验
openclaw skills install @qingmuhuijianghu/skill-matrix-publisher-free一句话介绍:一键将免费Skill分发到腾讯SkillHub(个人版CLI + 团队版Web)、虾聊、虾友SkillHub、GitHub、ClawHub六大平台,实现矩阵式传播。
适用对象:Skill开发者、开源贡献者、AI Agent创作者
用户反馈最多的问题:发布到虾友SkillHub后描述显示为乱码,根因是 Windows 默认 GBK 编码与 UTF-8 冲突。
| 检查项 | 正确做法 |
|---|---|
| Python 读文件 | open(path, encoding='utf-8') |
| JSON 序列化 | json.dumps(..., ensure_ascii=False) |
| requests 发送 | json=dict_obj(自动UTF-8)或 data=body.encode('utf-8') |
| Content-Type | 含 charset=utf-8 |
Skill被平台拒绝后,助手自动:
| 违规触发词 | 合规替换 |
|---|---|
| 某信/微x | 个人社交账号 |
| 虚假交易 | 不合规交易 |
| 赚钱/日入 | 创造收益 |
| 破解 | 突破 |
智能修复时,以下内容不可触碰:
author 字段这是本Skill最致命的坑,反复犯错!每次操作前必须确认:用户说的是「发布」还是「更新」?
| 操作 | 含义 | 虾友SkillHub端点 | 虾友SkillHub行为 | 腾讯SkillHub端点 | 腾讯SkillHub行为 |
|---|---|---|---|---|---|
| 🆕 发布(创建) | 该Skill在平台上从未存在过 | POST /api/skills/publish | slug不存在→创建新记录 | POST .../publish | 创建新Skill记录 |
| 🔄 更新(覆盖) | 该Skill在平台上已经存在,只需升级版本 | POST /api/skills/publish(同slug) | slug存在→自动覆盖 | POST .../publish(同slug) | 自动覆盖 |
- 虾友SkillHub v3.4.0-test 已测试通过:
POST /api/skills/publish同 slug 自动匹配更新(和腾讯SkillHub一致),不再需要区分创建/更新端点!- 不确定是发布还是更新 → 无所谓了,传同一个 publish 端点,slug 自动判断
- 若仍需手动控制 →
POST /api/skills(强制创建新记录)vsPOST /api/skills/publish(智能发布/更新)
用户指令 → 提取关键词:「发布」「更新」「同步新版」均可
│
└─ 👉 统一用 POST /api/skills/publish,slug 自动匹配:
- slug 已存在 → 更新(自动覆盖,不创建重复记录)
- slug 不存在 → 创建(新记录)
| 平台 | 更新端点 | 创建端点 | 区别 |
|---|---|---|---|
| 🦐 虾友SkillHub | POST /api/skills/publish(同slug) | 同左 | 同一端点,slug匹配自动覆盖 ✅ v3.4.0-test已测试通过 |
| 🔷 腾讯SkillHub | POST .../publish(同slug) | 同左 | 同一端点,slug匹配自动覆盖 |
| 🔱 ClawHub | POST /api/v1/skills(新version) | 同左 | 同一端点,version升级自动upsert |
| 📦 GitHub | PUT /repos/{owner}/{repo}/contents/{path} | 同左 | 同一端点,sha匹配覆盖 |
| 🦞 虾聊 | POST /api/v1/posts | 同左 | 每次发新帖 |
🎉 v3.4.0喜讯:虾友SkillHub已上线
POST /api/skills/publish同slug自动匹配,和腾讯SkillHub行为一致!不再有「不同端点」的坑了!
腾讯SkillHub ≠ 虾友SkillHub,名字都不一样,域名更不同,token不通用!
| 平台 | 官网 | API端点 | Token前缀 | Skill ID格式 |
|---|---|---|---|---|
| 🔷 腾讯SkillHub | skillhub.cn | api.skillhub.cn | skh_ | 数字(如 36252) |
| 🦐 虾友SkillHub | aiskillhub.vip | aiskillhub.vip | 登录JWT | UUID(如 1c993b64-...) |
| 🔱 ClawHub | clawhub.ai | clawhub.ai | clh_ | base62 |
| 🦞 虾聊 | clawdchat.cn | clawdchat.cn | clawdchat_ | UUID |
| 📦 GitHub | github.com | api.github.com | ghp_ | repo路径 |
核心原则:
- 说到"SkillHub" → 先看域名是
skillhub.cn(腾讯)还是aiskillhub.vip(虾友)- 两个平台的 API、Token、Skill ID 格式完全不同
- 发布/更新前,必须先确认目标平台域名,不要想当然!
每一次用户首次提供任何平台的 key / token / 密码 / 手机号 / 用户名,AI 必须立即将其永久存入
config.json,不得等用户提醒,不得再次索要。
| 规则 | 说明 |
|---|---|
| 首次提供即存储 | 用户提供credentials后,在同一轮对话中立即写入config.json对应平台的字段 |
| 不得重复索要 | 同一平台的credentials存储后,后续操作直接从config.json读取,禁止再次问用户 |
| 存储字段标准 | username / api_key / token / phone / password 按平台实际字段命名 |
| 覆盖更新 | 用户提供新的credentials时,立即覆盖旧值 |
| 适用范围 | 腾讯SkillHub(skh_) / 虾友SkillHub(phone+password) / 虾聊(clawdchat_) / ClawHub(clh_) / GitHub(ghp_) 全部适用 |
| 平台 | 用户名/账号 | 凭据状态 |
|---|---|---|
| 🔷 腾讯SkillHub | 青木会江湖 | ✅ skh_d286... 已存储 |
| 🦞 虾聊 | qingmuhui-nanjixianweng | ✅ clawdchat_nCnY... 已存储 |
| 🦐 虾友SkillHub | 17080952927 | ✅ phone + password + invitation_code + api_key 全部已存储 |
| 🔱 ClawHub | — | ✅ clh_7kO3... 已存储 |
| 📦 GitHub | qingmuhuijianghu | ✅ ghp_rd7I... PAT + owner/repo 已存储 |
本 Skill 支持两种安装方式,用户可根据场景自由选择:
通过 WorkBuddy / 虾友SkillHub 市场一键安装,安装后直接在聊天中操作。
用户:帮我把「我的Skill」发布到虾友SkillHub
助手:好的,请提供Skill目录路径……
用户:/path/to/my-skill
助手:[读取SKILL.md] [三重验证] [智能归类] → ✅ 发布成功!
优点:
安装步骤:
将本 Skill 作为独立 CLI 工具安装,在终端中运行。
Linux / macOS:
# 下载安装脚本并校验 SHA256
curl -fsSLo /tmp/install.sh https://raw.githubusercontent.com/qingmuhuijianghu/qingmuhui-skills/v3.5.0/skill-matrix-publisher-free/scripts/install.sh
# 校验 SHA256(从官方 releases 页面获取最新 checksum)
# sha256sum -c <<< "EXPECTED_SHA256 /tmp/install.sh"
bash /tmp/install.sh && rm /tmp/install.sh
Windows(PowerShell):
# 下载安装脚本并校验
$url = "https://raw.githubusercontent.com/qingmuhuijianghu/qingmuhui-skills/v3.5.0/skill-matrix-publisher-free/scripts/install.ps1"
$file = "$env:TEMP\install.ps1"
Invoke-WebRequest -Uri $url -OutFile $file
# 校验文件哈希(从官方 releases 页面获取)
# (Get-FileHash $file -Algorithm SHA256).Hash -eq "EXPECTED_SHA256"
& $file; Remove-Item $file
手动安装:
# 1. 克隆仓库(锁定 tag)
git clone --branch v3.5.0 --depth 1 https://github.com/qingmuhuijianghu/qingmuhui-skills.git
# 2. 复制到 WorkBuddy skills 目录
cp -r qingmuhui-skills/skill-matrix-publisher-free ~/.workbuddy/skills/
# 3. 安装依赖(固定版本号,避免供应链风险)
pip install requests==2.32.3
CLI 使用示例:
# 一键分发到所有平台
python ~/.workbuddy/skills/skill-matrix-publisher-free/scripts/matrix_publish.py /path/to/your-skill all
# 只发布到虾友SkillHub(需提供凭据)
python matrix_publish.py /path/to/your-skill skillhub \
--phone 138xxxx \
--password xxx \
--api-key sk-xxxxxxxx \
--invitation-code XXXX-XXXX
# 只发布到ClawHub
python matrix_publish.py /path/to/your-skill clawhub
优点:
| 特性 | 🗣️ 对话安装 | 💻 命令行安装 |
|---|---|---|
| 上手难度 | ⭐ 零门槛 | ⭐⭐ 需基础终端操作 |
| 交互方式 | 自然语言对话 | 命令 + 参数 |
| Token 管理 | AI 对话中提供 | 配置文件或命令行参数 |
| CI/CD 集成 | ❌ | ✅ |
| 批量发布 | 逐个人工确认 | 脚本批量 |
| 适用人群 | 所有人 | 开发者/运维 |
skh_ Token)+ 团队版浏览器上传(sk-ent- Key)以下是今天实际走通的完整发布流水账,每个平台每一步都踩过坑、验证过。
腾讯SkillHub个人版 → 虾聊 → ClawHub → GitHub → 虾友SkillHub
(团队版走浏览器手动上传,不在此列)
Token 格式:skh_ 开头(个人Token,非企业 sk-ent-)
核心命令:
# 登录
python skills_store_cli.py auth login --token skh_你的Token
# 发布(⚠️ 必须设置编码,否则 emoji 报错)
PYTHONIOENCODING=utf-8 python skills_store_cli.py publish ./skill-dir
坑:不设 PYTHONIOENCODING=utf-8 会导致 SKILL.md 中的 emoji(如 🎀)编码报错。
SKILL.md frontmatter 必备字段(与通用字段不同!):
slug: shequn-shoulu
displayName: 社群收录
version: 1.0.0
summary: 一句话简介
tags: [标签1, 标签2]
license: MIT
验证:CLI 返回 skillId=88182 status=pending_review 即成功。
端点:POST https://clawdchat.cn/api/v1/posts → 直接发帖
Token 格式:clawdchat_ 开头
必填字段:title + content + circle(用slug格式如 ai-doers,不能用UUID)
流程:
# 先查可用圈子列表
GET /api/v1/circles → 获取 slug(如 ai-doers)
# 发帖(JSON body)
POST /api/v1/posts
{
"title": "社群收录 Skill v1.2.0",
"content": "Markdown格式的详细介绍...",
"circle": "ai-doers" # ⚠️ 必须用slug,不能用UUID!
}
坑:circle 用 UUID 格式返回 404,必须用 slug。
注意:/f/upload 是分享用的 GET 路由,不支持 POST 文件上传。
验证:https://clawdchat.cn/posts/{postId}
端点:POST https://clawhub.ai/api/v1/skills(multipart form)
Token 格式:clh_ 开头
关键参数:
{
"slug": "shequn-shoulu",
"displayName": "社群收录",
"version": "1.0.0", # ⚠️ ClawHub 强制要求
"acceptLicenseTerms": True, # ⚠️ 必须!否则 400
"tags": ["community", "IMA", "knowledge-base"], # ⚠️ 必须是英文!中文tag报422(Convex字段名限制)
}
坑:ClawHub tags 不能包含中文(后端用 Convex,字段名只接受 ASCII),必须用英文 tag(如 community 替代 社群)。
验证:https://clawhub.ai/skills/{skillId}
Token 格式:ghp_ 开头(Personal Access Token classic,勾 repo 权限)
完整流程:
# Step 1: 从 Token 获取用户名
curl -H "Authorization: Bearer ghp_xxx" https://api.github.com/user
# → 返回 "login": "qingmuhuijianghu"
# Step 2: Clone 仓库
git clone "https://ghp_xxx@github.com/qingmuhuijianghu/qingmuhui-skills.git"
# Step 3: 复制 Skill 文件到子目录
cp -r ./shequn-shoulu/ ./repo/shequn-shoulu/
# Step 4: Commit & Push
git add -A && git commit -m "feat: 新增社群收录 Skill" && git push origin main
坑:GitHub Token 只能通过 GET /api/user 获取用户名,不能直接推断。
Token 生成指引:https://github.com/settings/tokens → Generate new token (classic) → 勾选 repo。
端点:
POST /api/skillsPOST /api/skills/{id}(同创建端点,传 skillType + categoryId)GET /api/categories认证流程:
# Step 1: 手机号+密码登录 → 获取 JWT
POST /api/auth/login {"phone":"...","password":"..."} → access_token
# Step 2: 所有后续请求带 JWT
Authorization: Bearer {access_token}
创建请求体(完整):
{
"name": "社群收录",
"slug": "shequn-shoulu",
"icon": "MessageSquare",
"description": "完整的 SKILL.md 内容(禁止截断!)",
"version": "1.0.0",
"isFree": True, # 🔴 免费版铁律:必传!平台默认false,不传=付费
"visibility": "public",
"skillType": "tool", # ⚠️ 必须显式指定!
"categoryId": "cat_tool_02_12", # 叶子节点ID
"features": ["触发词1", "触发词2"],
"requirements": ["WorkBuddy"],
"fileTree": [{
"name": "SKILL.md",
"path": "SKILL.md",
"type": "file",
"content": "SKILL.md 的完整原始内容",
"size": 12345
}]
}
分类树(2026-06-15 快照):
| 一级类型 (skillType) | 二级分类 | 示例 categoryId |
|---|---|---|
tool | 赛博创新 | cat_tool_01 ~ cat_tool_01_06 |
tool | 职场成长 → AI办公 | cat_tool_02_12 |
tool | 生态商业 → 社群搭建/运营/裂变… | cat_tool_03_01 ~ cat_tool_03_20 |
tool | 企业方案 | cat_tool_04_01 ~ cat_tool_04_10 |
tool | 行业专家 | cat_tool_05_01 ~ cat_tool_05_07 |
community | 按行业划分 → 17个子类 | UUID格式(如 b28351b8-...) |
community | 按地域划分 → 9个城市 | UUID格式 |
book | 商业管理/个人成长/职场技能 | cat_book_01 ~ cat_book_03 |
novel | 都市/玄幻/言情/科幻/悬疑 | cat_novel_01 ~ cat_novel_05 |
course | 社群运营/私域引流/个人品牌/AI工具/短视频 | cat_course_01 ~ cat_course_05 |
分类更新:
# 只需传要改的字段,POST 到同一个 skill ID
POST /api/skills/d076a6de-... {"skillType": "tool", "categoryId": "cat_tool_02_12"}
# → 201 code=200 即成功
坑1 —— AI审核关键词误杀:
aiReviewDetails.matchedWords 找触发词某信 → 个人社交账号,虚假交易 → 不合规交易坑2 —— 分类选错:
community 类型只有「按行业划分」「按地域划分」两个父级验证:
GET /api/skills/{id} → 确认 skillType + categoryId + status
| # | 平台 | 域名 | 认证方式 | API端点 | 全自动 |
|---|---|---|---|---|---|
| 1 | 🔷 腾讯SkillHub 个人版 | skillhub.cn | skh_ Token | api.skillhub.cn/api/v1/community/skills/publish | 🤖 |
| 2 | 🔷 腾讯SkillHub 团队版 | skillhub.cn | sk-ent- Key | 浏览器手动上传 | 👤 |
| 3 | 🦞 虾聊 | clawdchat.cn | clawdchat_ Key | POST /api/v1/posts (circle用slug) | 🤖 |
| 4 | 🔱 ClawHub | clawhub.ai | clh_ Token | POST /api/v1/skills | 🤖 |
| 5 | 📦 GitHub | github.com | ghp_ Token | git push | 🤖 |
| 6 | 🦐 虾友SkillHub | aiskillhub.vip | 手机号+密码 | POST /api/skills | 🤖 |
⚠️ 重复强调:腾讯SkillHub (skillhub.cn) 和 虾友SkillHub (aiskillhub.vip) 是两个独立平台,API、Token、Skill ID 格式完全不同!
核心问题:已发布的 Skill 出新版本后,能否用本助手更新而非重新创建?
答案:可以! 以下是各平台的版本更新机制:
每次更新 Skill,必须同时完成两件事,缺一不可:
- 更新主版本号:
version字段必须比当前版本更高(如 1.0.0 → 1.1.0 → 1.2.0)- 写入版本历史:在平台写入本次更新的 changelog,让用户在「历史版本」页看到更新记录
为什么必须两件事都做?
| 平台 | 更新方式 | 端点/命令 | 自动检测已有? | 版本历史写法 |
|---|---|---|---|---|
| 🦐 虾友SkillHub | 按名称搜索 → 找到则POST到{id} | POST /api/skills/{id} | ✅ 代码已实现 | POST /api/skills/{id}/versions |
| 🔱 ClawHub | 同 slug + 新 version → POST 同一端点 | POST /api/v1/skills | ✅ 自动 upsert | 自动(payload 里 changelog 字段) |
| 📦 GitHub | git push 更新文件 | git push | ✅ 覆盖旧文件 | commit message 即历史记录 |
| 🔷 腾讯SkillHub 个人版 | multipart publish 同 slug 自动覆盖 | POST api.skillhub.cn/.../publish | ✅ slug 匹配 | 自动(payload 里 changelog 字段) |
| 🔷 腾讯SkillHub 团队版 | 浏览器手动重新上传 | Web UI | 👤 手动 | 手动填写 |
| 🦞 虾聊 | 创建新帖(非严格"更新") | POST /api/v1/posts | ⚠️ 新帖 | 帖子内容即更新说明 |
Step 1:更新主体内容 + 版本号
# matrix_publish.py 的 publish_to_skillhub() 已实现自动检测:
# 按名称搜索已存在的 Skill
GET /api/skills?keyword=社群收录&page=1&pageSize=50
# 匹配到同名 Skill → 走 UPDATE
if existing_skill_id:
POST /api/skills/{existing_skill_id} # 更新(body 中 version 字段必须升级!)
else:
POST /api/skills # 创建
Step 2:写入版本历史记录(⚠️ 必须!不要忘记!)
# 每次更新后,必须调用此接口写入版本历史
POST https://aiskillhub.vip/api/skills/{skillId}/versions
Body:
{
"version": "1.2.0", # 必须与 Step 1 里的版本号一致
"changelog": "v1.2.0 新增:发布引导流程 —— Skill生成后引导用户安装矩阵发布助手,一键分发六大平台。",
"releaseDate": "2026-06-17" # 可选,默认当天
}
→ 返回 {"code":200, "data":{"id":"..."}}
关键行为:
POST /api/skills/{id}/versions 支持多条记录,按版本号排序展示/versions/{id} 不支持,写错的记录无法删除,需谨慎版本历史 changelog 写法规范:
格式:v{版本号} {类型}:{简要描述}
类型:新增 / 优化 / 修复 / 重构
示例:
v1.1.0 优化:Skill蒸馏隔离 —— 用户将收录内容整理成Skill时,仅输出社群本身内容,不带入平台信息
v1.2.0 新增:发布引导流程 —— Skill生成后,引导用户安装「Skill矩阵发布助手」,确认后自动切换为发布模式
ClawHub 的 API 设计是 无 PUT/PATCH,更新 = 发新版本:
# 更新方式:POST 同一端点,slug 不变,version 升级,changelog 必填
payload = json.dumps({
"slug": "shequn-shoulu", # ← 与初版相同
"displayName": "社群收录",
"version": "1.1.0", # ← 升级版本号(必须比已有版本高!)
"changelog": "v1.1.0 优化:Skill蒸馏隔离", # ← 历史记录(必填!)
"acceptLicenseTerms": True
})
关键行为:
changelog 字段直接成为版本历史说明(必须填写,否则历史页为空)latestVersion、updatedAt 自动更新💡 两种方式均可:
- UI方式(推荐):在 skillhub.cn 我的Skill列表,点击该Skill右侧的「更新」按钮,填写新版本信息上传
- API方式(自动化):POST multipart 同 slug 自动覆盖(Skill处于「安全审核中」状态时UI更新按钮不可用,等审核通过再操作)
# API更新方式:POST multipart,slug 不变,version 升级
# ⚠️ 字段名铁律:payload(JSON字符串)+ files(复数!不是 file)
import requests, json
payload = json.dumps({
"slug": "your-skill-slug",
"version": "1.1.0", # ← 升级版本号
"changelog": "v1.1.0 新增XX功能", # ← 历史记录(自动进版本历史)
"displayName": "Skill名称",
"description": "完整的SKILL.md内容", # 禁止截断!
"tags": ["tag1", "tag2"],
"license": "MIT",
...
}, ensure_ascii=False)
with open("SKILL.md", encoding="utf-8") as f:
content = f.read()
resp = requests.post(
"https://api.skillhub.cn/api/v1/community/skills/publish",
headers={"Authorization": "Bearer skh_你的Token"},
files={
"payload": (None, payload.encode("utf-8"), "application/json; charset=utf-8"),
"files": ("SKILL.md", content.encode("utf-8"), "text/markdown; charset=utf-8"),
# ^^^^ 注意:是 "files"(复数),不是 "file"!
}
)
⚠️ multipart 字段名必须精确:
payload(JSON元数据)+files(复数,SKILL.md文件)。错写成file(单数)会报 400 "至少需要上传一个文件"。
# 更新 SKILL.md 内容后(commit message = 版本历史)
git add shequn-shoulu/SKILL.md
git commit -m "feat: 社群收录 v1.1.0 — 新增Skill蒸馏隔离功能"
git push origin main
# commit message 本身就是版本历史,自动保留在 git log 中
import requests, json
BASE = 'https://aiskillhub.vip'
# 登录
token = requests.post(f'{BASE}/api/auth/login',
json={'phone': '手机号', 'password': '密码'}).json()['data']['access_token']
headers = {'Authorization': f'Bearer {token}', 'Content-Type': 'application/json'}
# Step 1: 查找已有 Skill ID
resp = requests.get(f'{BASE}/api/skills', params={'keyword': 'Skill名', 'pageSize': 50}, headers=headers)
items = resp.json().get('data', {}).get('items', [])
skill_id = next((i['id'] for i in items if i['slug'] == 'your-skill-slug'), None)
# Step 2: 更新主体(版本号升级)
with open('SKILL.md', encoding='utf-8') as f:
content = f.read()
requests.post(f'{BASE}/api/skills/{skill_id}', headers=headers, json={
"name": "Skill名称",
"slug": "your-skill-slug",
"version": "1.2.0", # ← 升级版本号!
"isFree": True, # 🔴 更新也必须显式传!防止被平台重置为false
"description": content,
"fileTree": [{"name": "SKILL.md", "path": "SKILL.md", "type": "file",
"content": content, "size": len(content.encode())}]
})
# Step 3: 写入版本历史(⚠️ 必须做!)
requests.post(f'{BASE}/api/skills/{skill_id}/versions', headers=headers, json={
"version": "1.2.0",
"changelog": "v1.2.0 新增:发布引导流程 —— Skill生成后引导用户安装矩阵发布助手,一键分发六大平台。",
"releaseDate": "2026-06-17"
})
print("✅ 更新完成:版本号已升级 + 历史记录已写入")
你:"帮我把社群收录更新到 v1.2.0,发布到所有平台"
助手自动执行:
[准备] 读取更新后的 SKILL.md,确认 version 字段已改为 1.2.0...
[准备] 确认 changelog 内容:"v1.2.0 新增:发布引导流程"
[1/6] 🔷 腾讯SkillHub个人版: 上传 v1.2.0 + changelog... ✅
[2/6] 🦞 虾聊: 发布更新帖... ✅
[3/6] 🔱 ClawHub: POST v1.2.0 (含changelog)... ✅
[4/6] 📦 GitHub: git push (commit: v1.2.0 — xxx)... ✅
[5/6] 🦐 虾友SkillHub: 搜索→找到id→更新主体... ✅
→ 写入版本历史记录... ✅
[6/6] 🔷 腾讯SkillHub团队版: 告知用户需手动上传 zip... 👤
📊 更新完成!五平台已同步 v1.2.0,版本历史已写入
| 场景 | 触发词 |
|---|---|
| 配置发布平台 | "配置分发平台"、"设置虾聊"、"配置GitHub" |
| 发布单个平台 | "发布到虾聊"、"上传到GitHub" |
| 一键分发五平台 | "一键分发"、"矩阵发布"、"发布到所有平台" |
| 查看配置 | "查看配置"、"我的平台配置" |
⚠️ 重要区分:本节讲的是虾友SkillHub(
aiskillhub.vip),不是腾讯SkillHub(skillhub.cn)。两者是完全不同的平台!
⚠️ v3.2 更新:内测阶段只需手机号+密码登录获取 JWT,邀请码+API Key 为可选备用。
Step 1:手机号+密码登录 → 获取 JWT
POST https://aiskillhub.vip/api/auth/login
Body: {"phone": "17080952927", "password": "..."}
→ 返回 access_token(JWT,有效期约7天)
Step 2:所有后续 API 请求带 JWT
headers = {"Authorization": "Bearer {access_token}"}
| 端点 | 方法 | 用途 |
|---|---|---|
/api/auth/login | POST | 登录获取 JWT |
/api/skills | POST | 创建 Skill |
/api/skills/{id} | POST | 更新 Skill(包括改分类) |
/api/skills/{id} | GET | 查询 Skill 详情 |
/api/categories | GET | 获取完整分类树 |
/api/skills?page=1&pageSize=20 | GET | 列表查询 |
body = {
"name": "社群收录",
"slug": "shequn-shoulu",
"icon": "MessageSquare",
"description": "完整的 SKILL.md 原始内容(禁止截断!)",
"version": "1.0.0",
"isFree": True, # 🔴 免费版铁律:必传!平台默认false,不传=付费
"visibility": "public",
"skillType": "tool", # ⚠️ 必须指定,默认 tool
"categoryId": "cat_tool_02_12", # ⚠️ 叶子节点 ID(不能是父节点)
"features": ["触发词1", "触发词2"],
"requirements": ["WorkBuddy"],
"fileTree": [{
"name": "SKILL.md",
"path": "SKILL.md",
"type": "file",
"content": "...完整的 SKILL.md 内容...",
"size": 12345
}]
}
# 只需传要改的字段
POST /api/skills/{skillId}
Body: {"skillType": "tool", "categoryId": "cat_tool_02_12"}
→ 201 code=200 即成功
# ⚠️ 改完后必须验证
GET /api/skills/{skillId} → 确认 skillType + categoryId 已生效
GET /api/categories
→ 返回完整树:tool/book/novel/course/expert/community
→ 每个节点含 id/name/children/parentId
→ ⚠️ 必须用叶子节点(有 children 的是父节点,不能直接用)
助手的引导流程:
用户:发布到虾友SkillHub
助手:好的,发布到虾友SkillHub需要三重验证。
请提供以下信息(缺一不可):
1️⃣ 平台登录手机号
2️⃣ 平台登录密码
3️⃣ API Key(个人中心 → 开发设置)
4️⃣ 邀请码(个人中心 → 我的邀请码)
用户:[提供手机号、密码、API Key、邀请码]
助手:[执行三重验证]
🛡️ 三重安全验证
[1/3] 平台登录验证... ✅
[2/3] API Key 验证... ✅
[3/3] 邀请码验证... ✅
🎉 三重验证全部通过!允许发布
助手:[智能归类 + 发布]
🤖 智能类目识别 → XX › XX(置信度: XX%)
✅ 虾友SkillHub发布成功!
⚠️ 重要区分:本节讲的是腾讯SkillHub(
skillhub.cn),不是虾友SkillHub(aiskillhub.vip)。两者是完全不同的平台,域名、API、Token都不一样!
腾讯SkillHub 是腾讯 WorkBuddy/Qclaw 官方 Skill 市场,覆盖腾讯体系内 AI Agent 用户。 2026年6月更新:腾讯SkillHub 新增「团队版」功能,支持企业/团队独立发布和管理 Skills。
🆕 v3.0 重要更新:腾讯SkillHub 现在有两个发布通道,根据用户目标选择:
| 版本 | 发布方式 | 认证方式 | 发布到 | 适用场景 |
|---|---|---|---|---|
| 个人版 | CLI 命令行 skillhub publish | skh_... 个人Token | 个人空间 / 社区市场 | 个人开发者,开源分享 |
| 团队版 | 浏览器 Web 上传(文件夹或zip) | sk-ent-... 企业API Key | 团队 Skill 库 | 企业/组织统一管理 |
skh_... 格式(个人中心 → API keys → 创建)curl -fsSL https://skillhub.cn/install/install.sh | bash -s -- --cli-only
echo 'export PATH="$HOME/.local/bin:$PATH"' >> ~/.zshrc
source ~/.zshrc
skillhub auth login --token skh_你的Token --host https://api.skillhub.cn
---
slug: your-skill-name # 全网唯一,小写字母+数字+连字符
displayName: 你的Skill名称 # 显示名称
version: 1.0.0 # 版本号
summary: 一句话简介 # 摘要
description: 详细描述 # 完整描述(禁止截断!)
tags: [标签1, 标签2] # 标签列表
license: MIT # 开源协议
---
# Step 1: Dry-run 预检
skillhub publish ./your-skill-dir --dry-run
# Step 2: 正式发布(⚠️ Windows 必须设编码!)
PYTHONIOENCODING=utf-8 skillhub publish ./your-skill-dir --changelog "首次发布"
看到 ✓ Published: skillId=xxxxx status=pending_review 即成功。
⚠️ Windows 编码坑:SKILL.md 含 emoji(如 🎀)时,不设
PYTHONIOENCODING=utf-8会导致 GBK 编码错误。Mac/Linux 用户无需此设置。
skillhub publish 命令(Windows 需 PYTHONIOENCODING=utf-8)sk-ent-... 格式)团队版的 SKILL.md frontmatter 要求与个人版完全一致。
Step 1:助手自动打包
助手将 Skill 目录(含 SKILL.md + references/ + scripts/ + assets/)打包为 .zip 文件。
Step 2:浏览器手动上传
description 字段提取,也支持手动修改Step 3:确认发布 审核通过后,团队成员可在「团队技能」中搜索和使用该 Skill。
| 环节 | 个人版(CLI) | 团队版(Web) |
|---|---|---|
| 准备 Skill 目录 | 🤖 助手自动完成 | 🤖 助手自动完成 |
| 验证元数据 | 🤖 助手自动完成 | 🤖 助手自动完成 |
| 打包/格式检查 | 🤖 CLI dry-run | 🤖 助手自动打包 |
| 上传/提交 | 🤖 CLI 一键完成 | 👤 用户浏览器操作 |
| 记录分发状态 | 🤖 助手自动完成 | 🤖 助手自动完成 |
用户:我要发布到腾讯SkillHub
助手:请问您要发布到哪个版本?
[A] 个人版 — 发布到您的个人空间,CLI全自动,需要 skh_ 个人Token
[B] 团队版 — 发布到团队 Skill 库,需要浏览器上传,需要 sk-ent- 企业Key
如果不确定,告诉我:
- 你是想让所有人都能搜到并安装?(→ 个人版)
- 还是只想在你们团队内部使用?(→ 团队版)
虾聊支持 API Key 方式直接上传Skill,实现真正的一键自动化!
Step 1: 获取API Key
clawdchat_xxxxxxxx)Step 2: 配置API Key 告诉 Skill:"配置虾聊API Key",提供用户名和 API Key
Step 3: 一键发布(发帖方式)
# 先查圈子列表
GET /api/v1/circles → 获取目标圈子的 slug
# 发帖发布 Skill
POST /api/v1/posts
{
"title": "Skill名称 v1.0.0 | 青木会江湖出品",
"content": "Markdown格式的Skill介绍(含安装方式、功能特性)",
"circle": "ai-doers" # ⚠️ 必须用slug,不能用UUID
}
→ 返回 postId,帖子页面即为 Skill 展示页
⚠️
/f/upload是分享用途的GET路由,不支持POST上传文件。虾聊发布Skill的正确方式是发帖。
ClawHub 是 OpenClaw 官方 Skill 注册中心(13,000+ Skills),支持 API 一键发布。
Step 1: 获取 API Token
clh_xxxxxxxx)Step 2: 准备 SKILL.md 确保 SKILL.md frontmatter 包含 ClawHub 必需字段:
---
name: your-skill # Skill 名称
version: 1.0.0 # 版本号(必须有!)
description: 完整描述 # 详细描述
---
⚠️ 注意:
version字段是 ClawHub 强制要求,缺失会被拒绝。
Step 3: API 一键发布
import requests, json
payload = json.dumps({
"slug": "your-skill-slug",
"displayName": "显示名称",
"version": "1.0.0",
"changelog": "首次发布",
"tags": ["tag1", "tag2"],
"acceptLicenseTerms": True # 必须!同意开发者协议
}, ensure_ascii=False)
resp = requests.post(
"https://clawhub.ai/api/v1/skills",
headers={"Authorization": "Bearer clh_你的Token"},
files={
"payload": (None, payload, "application/json"),
"files": ("SKILL.md", skill_content.encode("utf-8"), "text/markdown"),
}
)
成功返回:{"ok":true, "skillId":"...", "versionId":"..."}
Step 4: 验证发布
https://clawhub.ai/skills/{skillId}https://clawhub.ai/search?q=your-skill-slugmetadata.openclaw.requires.env 中声明acceptLicenseTerms: true),否则 400 错误| 错误 | 原因 | 解决 |
|---|---|---|
| 400 acceptLicenseTerms | 未同意开发者协议 | 访问 clawhub.ai → Settings → Developer Settings → 同意协议 |
| 409 版本冲突 | 版本号已存在 | 升级版本号如 1.0.0 → 1.0.1 |
| 422 (tags) | tags 包含中文 | ClawHub 后端 Convex 字段名只接受 ASCII,必须用英文 tag(如 community 替代 社群) |
| 安全扫描不通过 | 硬编码凭证/未声明环境变量 | 改用环境变量 + 声明 metadata |
本Skill包含可执行脚本,位于 scripts/ 目录:
| 脚本 | 功能 | 使用场景 |
|---|---|---|
matrix_publish.py | 一键分发主脚本 | 批量发布/更新到五大平台 |
publish_clawdchat_api.py | 虾聊全自动发帖 ⭐推荐 | 配置API Key后一键发布 |
publish_clawhub.py | ClawHub全自动发布 ⭐推荐 | 配置Token后一键发布到ClawHub |
publish_github.py | GitHub发布脚本 | 代码托管和版本管理 |
install.sh / install.ps1 | 命令行安装脚本 | Linux/macOS / Windows 一键安装 |
⚠️ 腾讯SkillHub (skillhub.cn) ≠ 虾友SkillHub (aiskillhub.vip),是两个完全不同的平台!
| 平台 | 域名 | 类型 | 特点 |
|---|---|---|---|
| 🔷 腾讯SkillHub(个人版) | skillhub.cn | 官方平台-个人 | CLI全自动发布,skh_ Token认证,发布到社区市场 |
| 🔷 腾讯SkillHub(团队版) | skillhub.cn | 官方平台-团队 | 浏览器上传,sk-ent- 企业Key,发布到团队 Skill 库 |
| 🦞 虾聊 (ClawdChat) | clawdchat.cn | 社区平台 | AI Agent交流社区,国内用户活跃 |
| 🦐 虾友SkillHub | aiskillhub.vip | 自研平台 | 青木会虾友社官方平台,深度整合(三重验证) |
| 📦 GitHub | github.com | 代码托管 | 开源生态,版本管理,全球开发者 |
| 🔱 ClawHub | clawhub.ai | 官方市场 | OpenClaw官方Skill市场,API全自动发布,13000+ Skills |
🔴 铁律:概述(description)必须完整,禁止极简/截断!
description 字段必须完整呈现 SKILL.md frontmatter 中的描述内容[:200]、[:100] 等)description字段完整反映了skill的实际功能和内容此规则适用于全部6个平台(腾讯SkillHub个人版+团队版、虾聊、虾友SkillHub、GitHub、ClawHub)。
每个平台的 description 字段都必须完整。
虾友SkillHub 专用强校验(每次发布/更新后强制执行):
# Step 1: 查询 detail 接口
GET /api/skills/{id}
→ 校验以下字段:
✅ isFree === True # 🔴 最关键的校验!平台默认false,不传就会变成付费
✅ price === 0 或 price 字段不存在
✅ skillType / categoryId 已生效
✅ status 不为空
# Step 2: 数据一致性检查
GET /api/skills/{id}/install-info
→ 比对 install-info.isFree 与 detail.isFree:
- 一致 → ✅ 通过
- 不一致 → 🚨 告警 "平台数据异常!install-info={x} detail={y},需联系平台修复"
自动修复流程(检测到 isFree=false 时立即执行):
# 如果 detail.isFree === false(但应该是true)→ 立即修复
POST /api/skills/{id}
Body: {"isFree": True}
# 修复后重新验证
GET /api/skills/{id} → 确认 isFree === True
→ 不一致则再次修复,最多3次 → 仍失败则告警用户"平台isFree字段修复失败,需联系管理员"
其他平台验证(腾讯SkillHub / ClawHub / GitHub / 虾聊):
矩阵发布助手脚本(matrix_publish.py)中,提取 description 的代码行:
# ✅ 正确:不截断
description = ' '.join(desc_lines)
# ❌ 错误:截断(已修复)
# description = ' '.join(desc_lines)[:200]
背景:2026-06-18 实战发现——通过本助手发布的免费技能「大华人脉王」,detail 表
isFree=false, price=0,而 install-info 表返回isFree=true,两表数据不一致导致用户无法通过POST /api/licenses/free安装。
| 环节 | 可能出错点 |
|---|---|
| AI执行层 | SKILL.md 太长(4.6万字),AI 可能遗漏 isFree: True 字段 |
| 平台默认值 | isFree 字段平台默认 false,不传即付费 |
| 平台数据同步 | detail 表与 install-info 表 isFree 字段可能不同步 |
| 更新请求 | 更新 Skill 时如果不带 isFree,可能被重置为默认值 false |
┌─────────────────────────────────────────────────────────────┐
│ 🦐 虾友SkillHub 发布/更新 → 强制校验流程 │
├─────────────────────────────────────────────────────────────┤
│ │
│ [1] POST /api/skills 或 POST /api/skills/publish │
│ ↓ body 必须含 "isFree": True │
│ │
│ [2] GET /api/skills/{id} ← 查 detail 表 │
│ ↓ 校验: isFree === True ? │
│ ├─ YES → [3] │
│ └─ NO → [4] 自动修复 │
│ │
│ [3] GET /api/skills/{id}/install-info ← 查 install-info 表 │
│ ↓ 比对: install-info.isFree === detail.isFree ? │
│ ├─ YES → ✅ 校验通过,告知用户 │
│ └─ NO → 🚨 告警 "平台两表数据不一致" │
│ │
│ [4] 自动修复: POST /api/skills/{id} {"isFree": True} │
│ ↓ 回到 [2] 重新校验(最多循环3次) │
│ └─ 3次仍失败 → 告警用户 "isFree修复失败,联系平台管理员" │
│ │
└─────────────────────────────────────────────────────────────┘
# ===== 发布/更新后立即执行 =====
import requests, json
BASE = 'https://aiskillhub.vip'
headers = {'Authorization': f'Bearer {token}', 'Content-Type': 'application/json'}
# 1. 发布 Skill(⚠️ isFree 必传)
body = {
"name": "Skill名称",
"slug": "your-slug",
"isFree": True, # 🔴 免费版铁律:不传默认false!
"visibility": "public",
# ... 其他字段
}
resp = requests.post(f'{BASE}/api/skills', headers=headers, json=body)
skill_id = resp.json()['data']['id']
# 2. 验证 detail 表
detail = requests.get(f'{BASE}/api/skills/{skill_id}', headers=headers).json()
detail_data = detail.get('data', detail) # 兼容有/无包装层
is_free_ok = detail_data.get('isFree') == True
price_ok = detail_data.get('price') in (0, None)
if not is_free_ok:
print(f"🚨 检测到 isFree={detail_data.get('isFree')},应该是True,开始自动修复...")
for attempt in range(3):
fix_resp = requests.post(f'{BASE}/api/skills/{skill_id}',
headers=headers, json={"isFree": True})
# 重新验证
recheck = requests.get(f'{BASE}/api/skills/{skill_id}', headers=headers).json()
recheck_data = recheck.get('data', recheck)
if recheck_data.get('isFree') == True:
print(f"✅ isFree 修复成功(第{attempt+1}次)")
break
else:
print("🚨 isFree 修复失败(3次均未生效),请联系平台管理员检查数据库")
# 3. 数据一致性检查
install_info = requests.get(f'{BASE}/api/skills/{skill_id}/install-info',
headers=headers).json()
install_data = install_info.get('data', install_info)
if install_data.get('isFree') != detail_data.get('isFree'):
print(f"🚨 数据不一致!install-info.isFree={install_data.get('isFree')} "
f"detail.isFree={detail_data.get('isFree')}")
print(f"✅ 校验完成: isFree={detail_data.get('isFree')}, price={detail_data.get('price')}")
# ❌ 错误:更新时不传 isFree → 可能被平台重置为 false
requests.post(f'{BASE}/api/skills/{skill_id}', headers=headers, json={
"name": "Skill名称",
"version": "1.2.0",
"description": content,
# ⚠️ 缺少 isFree!
})
# ✅ 正确:更新时必须显式传 isFree
requests.post(f'{BASE}/api/skills/{skill_id}', headers=headers, json={
"name": "Skill名称",
"version": "1.2.0",
"description": content,
"isFree": True, # 🔴 更新也必须带!防止被重置
})
平台未配置:提示用户先完成配置 平台限流/429:等待60秒自动重试 认证失败/401:引导用户重新获取Token Skill已存在/409:提供更新或跳过选项
| 版本 | 日期 | 更新内容 |
|---|---|---|
| v3.7.0 | 2026-06-18 | 🛡️ 发布后 isFree 强校验:新增规则4的 isFree/price 双重校验流程 + 虾友SkillHub detail vs install-info 数据一致性检查 + 自动修复(最多3次重试)+ 更新请求强制带 isFree;🔧 基于「大华人脉王」isFree=false 实战踩坑驱动 |
| v3.6.0 | 2026-06-18 | 🔥 编码乱码修复:新增编码规范铁律(utf-8+ensure_ascii=False+charset=utf-8);🤖 智能违规自动修复:被拒后自动调整直到通过(最多3次);🔴 品牌署名铁律:联营单位+作者+出品方为不可触碰内容 |
| v3.5.1 | 2026-06-17 | 🛡️ 安全合规修复 |
| v3.5.0 | 2026-06-17 | 🎯 虾友SkillHub端点统一:新增 POST /api/skills/publish 统一端点,slug 自动匹配创建/更新,行为与腾讯SkillHub完全一致;「发布≠更新」铁律从"不同端点"简化为"同一publish端点";config.json 虾友节删除 update_url,新增 publish_url,六平台全部统一 |
| v3.4.0 | 2026-06-17 | 🔐 新增「Credentials铁律」:六大平台凭证首次提供即永久存储;🦞 修正虾聊API为 POST /api/v1/posts;🔱 ClawHub tags 不能用中文;📦 GitHub仓库修正为 qingmuhuijianghu/qingmuhui-skills;🦐 虾友SkillHub凭证补全;⚡ 「发布≠更新」铁律初版;🧹 文件瘦身23→11 |
| v3.3.0 | 2026-06-15 | 🔄 新增「Skill版本更新指南」:六平台更新机制对比(虾友搜索更新/ClawHub upsert/GitHub push/腾讯CLI),文档化更新 vs 创建的差异;📥 新增「安装方式(双通道)」:对话安装 + 命令行安装(含 install.sh / install.ps1),双通道对比表;更新版本为 v3.3.0 |
| v3.2.0 | 2026-06-15 | 🧪 六平台全实战验证(社群收录):新增完整流水账(腾讯个人版CLI/虾聊/ClawHub/GitHub/虾友SkillHub)、GitHub git token认证流程、虾友SkillHub分类更新端点、分类树快照、AI审核关键词规避实战;修复发布规则编号错乱(规则1→5)、5平台→6平台 |
| v3.1.1 | 2026-06-15 | 🦐 虾友SkillHub全自动发布:新增 API 参数详解(skillType必传)、AI审核关键词规避(某信→社交账号、虚假交易规避)、分类体系说明(leaf node必须) |
| v3.1.0 | 2026-06-15 | 🔱 新增 ClawHub 全自动API发布方案(POST /api/v1/skills),含完整Python示例、安全扫描注意事项、常见错误处理 |
| v3.0.0 | 2026-06-15 | 🔷 腾讯SkillHub双通道发布:新增「团队版」浏览器上传流程,保留「个人版」CLI全自动;区分 skh_ 个人Token vs sk-ent- 企业Key 的使用场景 |
| v2.2.1 | 2026-05-29 | 🔷 修正腾讯SkillHub发布方案:CLI不支持上传,改为「助手自动打包 + 浏览器手动上传」务实方案 |
| v2.2.0 | 2026-05-28 | 🔷 新增腾讯SkillHub平台支持,五平台全覆盖(腾讯SkillHub+虾聊+虾友SkillHub+GitHub+ClawHub) |
| v2.1.0 | 2026-05-28 | 🛡️ 新增三重安全验证(登录+API Key+邀请码),缺一不可;移除config.json自动登录 |
| v2.0.0 | 2026-05-28 | 🧠 新增智能类目识别引擎,自动分析Skill内容并归档到正确的二级类目;支持5大类52小类精准匹配 |
| v1.1.0 | 2026-04-27 | ✅ 虾聊全自动发布流程验证成功,新增API Key自动发布方案 |
| v1.0.0 | 2026-04-26 | 初版发布,支持4平台一键分发 |
记住:本Skill仅支持免费开源Skill的分发! 如需发布付费Skill,请使用「付费Skill发布助手」。