魔塔社区(ModelScope)API 完整手册
概述
本 Skill 封装魔塔社区全部可用 API,包括:模型库、数据集、技能中心(80K+ 技能)、MCP 广场(9.4K+ 服务器)。支持Token自动引导注册。
两种响应格式注意:
/api/v1/*(旧):PascalCase →{"Code": 200, "Data": {...}}/openapi/v1/*(新):snake_case →{"success": true, "data": {...}}
第一步:Token 设置(首次使用必读)
⚠️ 安全警告:此技能包含只读操作和变更操作。部署、删除、安装等变更操作需要你明确确认。请使用最小必要权限的 Token。
权限建议
| 操作类型 | 所需权限 | 说明 |
|---|---|---|
| 只读操作(搜索、查询) | 读取权限 | 无需 Token,公开可用 |
| 下载操作(模型、数据集) | 下载权限 | 需要 Token |
| 变更操作(创建、部署、删除) | 写入权限 | 必须明确用户确认 |
💡 建议:优先使用只读 Token,仅在需要下载/部署时才提供写入权限。
Token 获取与使用原则
🔒 核心原则:Token 只在当前会话中使用,不写入任何文件,不保存到记忆。
Token 优先级(从上到下):
- 环境变量
MODELSCOPE_API_TOKEN(最安全,推荐) - 直接提供(没有环境变量时,AI 会直接询问你)
没有 Token 时:直接告诉 AI「我的魔塔 Token 是 xxx」,AI 会在本次会话中使用它,执行完即丢弃。
情况 A:已有 Token
方式一(推荐):设置环境变量
export MODELSCOPE_API_TOKEN="ms-xxxxxx"
方式二:直接告诉 AI(AI 不会记录,仅当前会话使用)
没有 Token → 引导注册:
- 打开注册页面:https://www.modelscope.cn/my/overview
- 用手机号/支付宝/钉钉完成注册登录
- 登录后,点右上角头像 → 「访问令牌」(Access Token)
- 点「新建令牌」,填写名称(如
workbuddy) - ⚠️ 重要:权限选择「只读」或「下载」,除非你需要部署功能,否则不要选「全部」
- 复制生成的 Token(格式:
ms-xxxxxx),只显示一次,务必保存
⚠️ Token 即密码,不要提交到 GitHub。
获取 Token 后,直接告诉 AI 或设置环境变量,AI 在当前会话中使用后即丢弃,不记录。
能力一:技能中心(Skills)
总技能数:80,505+
1.1 搜索/列出技能
curl -s "https://www.modelscope.cn/openapi/v1/skills?page_number=1&page_size=10&search=股票" | python -m json.tool
Query 参数:
| 参数 | 类型 | 说明 |
|---|---|---|
page_number | int | 页码,默认 1 |
page_size | int | 每页数量,默认 10 |
search | string | 搜索关键词(匹配 display_name) |
无需 Token 即可访问。
响应示例:
{
"success": true,
"data": {
"total": 80505,
"skills": [
{
"id": "@Alipay/alipay-payment-integration",
"display_name": "支付宝支付集成skill",
"description": "...",
"category": "developer-tools",
"view_count": 21881,
"downloads": 2069
}
]
}
}
1.2 获取技能详情(含安装命令)
curl -s "https://www.modelscope.cn/openapi/v1/skills/@Alipay/alipay-payment-integration" | python -m json.tool
返回额外字段 install_command(3 种安装方式):
{
"install_command": [
"npx skills add https://modelscope.cn/skills/@Alipay/alipay-payment-integration",
"curl -fsSL https://modelscope.cn/skills/install.sh | bash -s -- @Alipay/alipay-payment-integration",
"pip install --upgrade modelscope && modelscope skills add @Alipay/alipay-payment-integration"
]
}
1.3 下载技能(需 Token)
🔒 下载操作:需要 Token 权限,但不会修改账户数据。
from modelscope.hub.api import HubApi
api = HubApi(token="ms-xxxxxx")
skill_dir = api.download_skill(skill_id="@Alipay/alipay-payment-integration")
print(f"技能已下载到: {skill_dir}")
⚠️ 安装到本地前,请确认该技能的来源和用途。
底层 API(一般不直接调用):
GET /api/v1/skills/{path}/{name}/archive/zip/master Header: Cookie: m_session_id={token}
### 1.4 技能分类列表
| 分类 ID | 说明 |
|----------|------|
| `developer-tools` | 开发工具 |
| `ai-media` | AI 媒体 |
| `skill-management` | 技能管理 |
| `cloud-devops` | 云 DevOps |
| `frontend-development` | 前端开发 |
| `code-quality-testing` | 代码质量测试 |
| `marketing-seo` | 营销 SEO |
| `ai-automation` | AI 自动化 |
| `doc-processing` | 文档处理 |
---
## 能力二:MCP 广场
> 总 MCP 服务器数:**9,477+**
### 2.1 搜索/列出 MCP 服务器
```bash
curl -s -X PUT "https://www.modelscope.cn/openapi/v1/mcp/servers" \
-H "Content-Type: application/json" \
-d '{"filter": {"category": "developer-tools"}, "page_number": 1, "page_size": 10, "search": ""}' | python -m json.tool
Body 参数:
| 参数 | 类型 | 说明 |
|---|---|---|
filter.category | string | 分类过滤(见下方分类表) |
filter.tag | string | 标签过滤 |
filter.is_hosted | bool | 是否只查托管服务器 |
page_number | int | 页码,默认 1 |
page_size | int | 每页数量,最大 100,默认 20 |
search | string | 搜索(匹配中文名/英文名/作者) |
filter中的多个条件取交集;search与filter可组合使用。
无需 Token 即可访问列表。
响应示例:
{
"success": true,
"data": {
"total_count": 9477,
"mcp_server_list": [
{
"id": "@modelcontextprotocol/fetch",
"name": "Fetch网页内容抓取",
"chinese_name": "Fetch网页内容抓取",
"description": "该服务器使大型语言模型能够检索和处理网页内容...",
"categories": ["browser-automation"],
"view_count": 457094
}
]
}
}
2.2 获取 MCP 服务器详情(含配置)
curl -s "https://www.modelscope.cn/openapi/v1/mcp/servers/@modelcontextprotocol/fetch?get_operational_url=true" | python -m json.tool
返回关键字段:
| 字段 | 说明 |
|---|---|
server_config | MCP 客户端配置(command + args),直接用于 mcp.json |
readme | 服务器说明文档(Markdown) |
is_hosted | 是否已触发托管服务 |
is_verified | 是否官方认证 |
env_schema | 环境变量 JSON Schema(如需配置 API Key) |
source_url | 源码地址(通常是 GitHub) |
github_stars | GitHub 星标数 |
server_config 示例(直接复制到 MCP 客户端配置):
{
"mcpServers": {
"fetch": {
"command": "uvx",
"args": ["mcp-server-fetch"]
}
}
}
2.3 获取用户运行中的 MCP 服务器(需 Token)
curl -s "https://www.modelscope.cn/openapi/v1/mcp/servers/operational" \
-H "Authorization: Bearer ms-xxxxxx" | python -m json.tool
⚠️ 此端点必须传 Token,否则返回 401。
2.4 MCP 分类列表(27 个)
| 分类 ID | 说明 | 分类 ID | 说明 |
|---|---|---|---|
ai-gc | AI 生成 | browser-automation | 浏览器自动化 |
communication | 通讯 | content-management-systems | 内容管理 |
databases | 数据库 | data-platforms | 数据平台 |
developer-tools | 开发工具 | entertainment-and-media | 娱乐媒体 |
finance | 金融 | file-systems | 文件系统 |
image-and-video-processing | 图像视频 | knowledge-and-memory | 知识记忆 |
location-services | 位置服务 | monitoring | 监控 |
note-taking | 笔记 | other | 其他 |
os-automation | 系统自动化 | research-and-data | 研究数据 |
search | 搜索 | travel-and-transportation | 出行交通 |
version-control | 版本控制 | cloud-platforms | 云平台 |
art-and-culture | 艺术文化 | calendar-management | 日历管理 |
能力三:模型库(Models)
总模型数:194,001+
3.1 列出模型
curl -s -X PUT "https://www.modelscope.cn/api/v1/models" \
-H "Authorization: Bearer ms-xxxxxx" \
-H "Content-Type: application/json" \
-d '{"page_number": 1, "page_size": 10, "search": "llama"}' | python -m json.tool
⚠️ 模型 API 使用旧格式(
/api/v1/,PascalCase)
响应格式:
{
"Code": 200,
"Success": true,
"Data": {
"TotalCount": 194001,
"Models": [...]
}
}
3.2 获取模型详情
curl -s "https://www.modelscope.cn/api/v1/models/{owner}/{name}" \
-H "Authorization: Bearer ms-xxxxxx" | python -m json.tool
3.3 下载模型
curl -s "https://www.modelscope.cn/api/v1/models/{owner}/{name}/archive/zip/{rev}" \
-H "Authorization: Bearer ms-xxxxxx" -o model.zip
或用 SDK(推荐):
from modelscope.hub.api import HubApi
api = HubApi(token="ms-xxxxxx")
model_dir = api.download_model(model_id="qwen/Qwen-7B")
3.4 常用模型端点汇总
| 端点 | 方法 | 说明 |
|---|---|---|
/api/v1/models | PUT | 列出模型(分页/搜索) |
/api/v1/models/{owner}/{name} | GET | 获取模型详情 |
/api/v1/models/{owner}/{name}/archive/zip/{rev} | GET | 下载模型(ZIP) |
/api/v1/models/{owner}/{name}/repo/tag | POST | 创建标签 |
/api/v1/models/{owner}/{name}/repo/files | GET | 获取模型文件列表 |
能力四:数据集(Datasets)
4.1 列出数据集
curl -s -X PUT "https://www.modelscope.cn/api/v1/datasets" \
-H "Authorization: Bearer ms-xxxxxx" \
-H "Content-Type: application/json" \
-d '{"page_number": 1, "page_size": 10, "search": "finance"}' | python -m json.tool
4.2 获取数据集详情
curl -s "https://www.modelscope.cn/api/v1/datasets/{namespace}/{name}" \
-H "Authorization: Bearer ms-xxxxxx" | python -m json.tool
4.3 获取数据集文件树
curl -s "https://www.modelscope.cn/api/v1/datasets/{namespace}/{name}/repo/tree" \
-H "Authorization: Bearer ms-xxxxxx" | python -m json.tool
4.4 常用数据集端点汇总
| 端点 | 方法 | 说明 |
|---|---|---|
/api/v1/datasets | PUT | 列出数据集 |
/api/v1/datasets/{ns}/{name} | GET | 获取数据集详情 |
/api/v1/datasets/{ns}/{name}/repo/tree | GET | 获取文件树 |
/api/v1/datasets/{ns}/{name}/archive/zip/{rev} | GET | 下载数据集(ZIP) |
能力五:创空间(Studios)
创空间(Studio)提供 MCP 工具和 HTTP API 两种操作方式。
前置条件:需要
MODELSCOPE_API_TOKEN,获取方式见「第一步:Token 设置」。
⚠️ 【重要】变更操作需要用户明确确认:以下操作会创建、修改或删除资源,执行前必须获得用户确认。
5.1 MCP 工具(推荐)
配置 ModelScope MCP 服务后,可直接调用以下工具:
| 操作类型 | 操作 | 工具 | 说明 |
|---|---|---|---|
| 🔒 只读 | 获取用户信息 | getCurrentUser | 获取当前用户名 |
| ⚠️ 变更 | 创建创空间 | createStudio | 需确认 - 在账户中创建新资源 |
| 🔒 只读 | 获取创空间详情 | getStudio | 查看现有资源 |
| ⚠️ 变更 | 更新设置 | updateStudioSettings | 需确认 - 修改配置 |
| ⚠️ 变更 | 部署(启动/重启) | deployStudio | 需确认 - 触发构建和部署 |
| ⚠️ 变更 | 停止 | stopStudio | 需确认 - 停止服务 |
| 🔒 只读 | 获取日志 | getStudioLogs | 查看运行日志 |
| 🔒 只读 | 环境变量列表 | listStudioSecrets | 查看变量(不含值) |
| ⚠️ 变更 | 添加环境变量 | addStudioSecret | 需确认 - 添加新变量 |
| ⚠️ 变更 | 更新环境变量 | updateStudioSecret | 需确认 - 修改变量 |
| ⚠️ 变更 | 删除环境变量 | deleteStudioSecret | 需确认 - 删除变量 |
5.2 HTTP API(MCP 不可用时的备选)
基础地址:https://modelscope.cn/openapi/v1,所有请求需携带 Authorization: Bearer ${MODELSCOPE_API_TOKEN}。
MCP 服务管理(配置 MCP 前使用)
| 操作类型 | 操作 | 方法 | 端点 |
|---|---|---|---|
| 🔒 只读 | 查询 MCP 服务详情 | GET | /mcp/servers/{id}?get_operational_url=true |
| ⚠️ 变更 | 部署 MCP 服务 | POST | /mcp/servers/{id}/deploy (需确认) |
创空间操作
| 操作类型 | 操作 | 方法 | 端点 | Body |
|---|---|---|---|---|
| 🔒 只读 | 获取当前用户 | GET | /users/me | — |
| ⚠️ 变更 | 创建创空间 | POST | /studios | {owner, repo_name, ...} (需确认) |
| 🔒 只读 | 获取创空间详情 | GET | /studios/{owner}/{repo_name} | — |
| ⚠️ 变更 | 更新创空间设置 | PATCH | /studios/{owner}/{repo_name}/settings | (需确认) |
| ⚠️ 变更 | 部署创空间 | POST | /studios/{owner}/{repo_name}/deploy | (需确认) |
| ⚠️ 变更 | 停止创空间 | POST | /studios/{owner}/{repo_name}/stop | (需确认) |
| 🔒 只读 | 获取日志 | GET | /studios/{owner}/{repo_name}/logs/{log_type} | — |
| 🔒 只读 | 获取环境变量列表 | GET | /studios/{owner}/{repo_name}/secrets | — |
| ⚠️ 变更 | 添加环境变量 | POST | /studios/{owner}/{repo_name}/secrets | (需确认) |
| ⚠️ 变更 | 更新环境变量 | PUT | /studios/{owner}/{repo_name}/secrets | (需确认) |
| ⚠️ 变更 | 删除环境变量 | DELETE | /studios/{owner}/{repo_name}/secrets | (需确认) |
完整 OpenAPI 文档:https://modelscope.cn/.well-known/openapi.json
5.3 实战经验(来自 fortune-mcp 部署验证)
sdk_type 选择关键差异:
| sdk_type | push 后行为 | 适用场景 |
|---|---|---|
docker | 不自动重建,需手动调用 deployStudio | FastAPI、自定义服务 |
gradio | 自动识别 app.py 中的 demo 变量并启动 | Gradio 应用 |
streamlit | 自动启动 Streamlit | Streamlit 应用 |
static | 直接托管静态文件 | 纯前端 |
⚠️
docker模式 push 后页面不变是常见问题,改用gradio或手动调deployStudio可解决。
Git 推送要点:
- 默认分支
master(不是main),禁止 force push - 推送地址:
https://oauth2:${TOKEN}@www.modelscope.cn/studios/${owner}/${repo_name}.git - 首次推送前需
fetch+merge --allow-unrelated-histories
Gradio 模式要求:
- 入口文件:
app.py(固定) - 必须有全局
demo变量:demo = gr.Blocks(title="...") requirements.txt需含gradio>=4.0.0- 平台自动调用
demo.launch(server_name="0.0.0.0", server_port=7860)
MCP 服务在创空间中运行:
FastMCP.http_app(transport="sse")必须显式指定 transport(默认是 streamable-http,注册/mcp而非/sse)- MCP SSE 需用独立线程运行,不能阻塞 Gradio 主线程
- 端口必须
0.0.0.0,禁止8080(平台占用)
💡 完整的部署实战经验和踩坑记录见
modelscope-studioSkill。
Python SDK 快速使用
安装
pip install modelscope
技能操作
from modelscope.hub.api import HubApi
from modelscope.hub.mcp_api import MCPApi
# 初始化(Token 可选,无 Token 只能访问公开数据)
api = HubApi(token="ms-xxxxxx")
mcp = MCPApi(token="ms-xxxxxx")
# 登录(保存 Cookie 到本地,30 天有效)
git_token, cookies = api.login()
# 下载技能
skill_dir = api.download_skill(skill_id="@Alipay/alipay-payment-integration")
print(f"技能已下载到: {skill_dir}")
# 列出 MCP 服务器(无需 Token)
result = mcp.list_mcp_servers(
filter={"category": "developer-tools"},
total_count=20,
search=""
)
print(f"总数: {result['total_count']}")
# 搜索 MCP 服务器
result = mcp.list_mcp_servers(search="高德")
# 获取 MCP 详情
detail = mcp.get_mcp_server(server_id="@amap/amap-maps")
print(f"配置: {detail['server_config']}")
# 获取运行中的 MCP(需 Token)
running = mcp.list_operational_mcp_servers()
CLI 命令
# 登录
modelscope login --token ms-xxxxxx
# 安装技能(并发下载,默认 8 线程)
modelscope skills add @Alipay/alipay-payment-integration
# 安装多个
modelscope skills add @steipete/github @steipete/weather --max-workers 8
# 指定安装目录
modelscope skills add @Alipay/alipay-payment-integration --local_dir ./my-skills
热门资源 Top 10
技能 Top 10(按下载量)
| 排名 | 名称 | ID | 下载量 |
|---|---|---|---|
| 1 | self-improvement | @pskoett/self-improving-agent | 2,377 |
| 2 | 支付宝支付集成 | @Alipay/alipay-payment-integration | 2,069 |
| 3 | find-skills | @vercel-labs/find-skills | 2,000 |
| 4 | frontend-design | @anthropics/frontend-design | 2,304 |
| 5 | web-search | @inference-sh/web-search | 1,360 |
MCP 服务器 Top 10(按浏览量)
| 排名 | 名称 | ID | 浏览量 |
|---|---|---|---|
| 1 | Fetch 网页抓取 | @modelcontextprotocol/fetch | 457K |
| 2 | 高德地图 | @amap/amap-maps | 290K |
| 3 | 12306 车票 | @Joooook/12306-mcp | 182K |
| 4 | 必应搜索中文 | slcatwujian/bing-cn-mcp-server | 154K |
| 5 | 可视化图表 | antvis/mcp-server-chart | 107K |
响应格式速查
| 路径前缀 | Key 风格 | 成功标志 | 数据字段 |
|---|---|---|---|
/api/v1/ | PascalCase | Success: true | Data |
/openapi/v1/ | snake_case | success: true | data |
代码示例(通用解析):
import requests
def ms_request(url, token=None):
headers = {"Authorization": f"Bearer {token}"} if token else {}
r = requests.get(url, headers=headers)
d = r.json()
# 兼容两种格式
if "Data" in d:
return d["Data"] # /api/v1/ 格式
elif "data" in d:
return d["data"] # /openapi/v1/ 格式
else:
raise ValueError(f"未知响应格式: {d}")
# 用法
skills = ms_request("https://www.modelscope.cn/openapi/v1/skills?page_size=5")
print(skills["total"]) # → 80505