S3-Compatible 3D Storage MCP Server
An MCP server for managing and publishing 3D files using S3-compatible storage providers like Cloudflare R2 and AWS S3. It enables users to upload models, generate interactive 3D viewers, and manage temporary access via presigned URLs.
README
🎨 S3-Compatible 3D Storage MCP Server
一个部署在 Vercel 上的 MCP 服务器,使用 S3 兼容 API 存储和发布 3D 文件。支持 Cloudflare R2、AWS S3、MinIO 等所有 S3 兼容存储。
✨ 特性
- ✅ S3 兼容存储: 支持 Cloudflare R2、AWS S3、MinIO、DigitalOcean Spaces 等
- ✅ 简单易用: 基于标准 S3 API,无需复杂配置
- ✅ 自动生成预览: 自动创建交互式 3D 模型查看器
- ✅ 预签名 URL: 支持生成临时访问链接
- ✅ 文件管理: 列出、上传、获取文件
🚀 快速开始
1. 安装依赖
npm install
2. 配置 S3 存储
创建 .env.local 文件并配置 S3 凭据:
使用 Cloudflare R2(推荐)
# 1. 登录 Cloudflare Dashboard
# 2. 进入 R2 -> Create Bucket -> 创建名为 "3d-models" 的存储桶
# 3. 进入 R2 -> Manage R2 API Tokens -> Create API Token
# 4. 复制 Account ID、Access Key ID 和 Secret Access Key
R2_ENDPOINT=https://<YOUR_ACCOUNT_ID>.r2.cloudflarestorage.com
R2_ACCESS_KEY_ID=<YOUR_ACCESS_KEY_ID>
R2_SECRET_ACCESS_KEY=<YOUR_SECRET_ACCESS_KEY>
R2_BUCKET_NAME=3d-models
# 可选:配置 R2 自定义域名(用于公开访问)
S3_PUBLIC_URL=https://your-custom-domain.com
使用 AWS S3
S3_ENDPOINT=https://s3.amazonaws.com
S3_ACCESS_KEY_ID=<YOUR_AWS_ACCESS_KEY>
S3_SECRET_ACCESS_KEY=<YOUR_AWS_SECRET_KEY>
S3_BUCKET_NAME=3d-models
3. 本地测试
npm run dev
访问 http://localhost:3000 查看服务器信息
4. 部署到 Vercel
# 方式一:命令行部署
vercel --prod
# 方式二:GitHub 自动部署(推荐)
git push origin main
重要:部署后在 Vercel 项目设置中添加环境变量:
- 进入项目 Settings → Environment Variables
- 添加
R2_ENDPOINT、R2_ACCESS_KEY_ID、R2_SECRET_ACCESS_KEY等 - 重新部署
📡 MCP 端点
部署后的 MCP 服务器地址:
https://your-project.vercel.app/api/mcp
🛠️ 可用工具
1. s3_upload_file
上传 3D 模型文件到 S3 兼容存储
参数:
{
"fileName": "model.glb",
"fileData": "base64_encoded_data",
"contentType": "model/gltf-binary",
"metadata": {
"title": "My 3D Model",
"description": "A beautiful 3D model"
}
}
返回:
{
"success": true,
"key": "3d-models/abc123-model.glb",
"url": "https://your-domain.com/3d-models/abc123-model.glb",
"id": "abc123",
"bucket": "3d-models"
}
2. s3_list_files
列出 S3 存储中的所有文件
参数:
{
"prefix": "3d-models/",
"maxKeys": 100
}
返回:
{
"success": true,
"bucket": "3d-models",
"count": 5,
"files": [
{
"key": "3d-models/abc123-model.glb",
"size": 1048576,
"lastModified": "2024-12-04T10:30:00Z"
}
]
}
3. s3_get_presigned_url
获取文件的预签名 URL(临时访问链接)
参数:
{
"fileName": "3d-models/abc123-model.glb",
"expiresIn": 3600
}
返回:
{
"success": true,
"url": "https://...presigned-url...",
"expiresIn": 3600
}
4. generate_3d_viewer
生成 3D 模型预览网页
参数:
{
"modelUrl": "https://your-domain.com/3d-models/model.glb",
"title": "My 3D Model",
"backgroundColor": "#111",
"cameraOrbit": "45deg 75deg auto"
}
🔧 MCP 客户端配置
在 Cursor 或其他 MCP 客户端中配置:
{
"mcpServers": {
"3d-storage": {
"url": "https://your-project.vercel.app/api/mcp"
}
}
}
💡 使用示例
Agent 调用示例
用户: 帮我上传这个 3D 模型文件到云端
Agent:
1. 调用 s3_upload_file 上传文件
→ 获得文件 URL: https://domain.com/3d-models/abc123-model.glb
2. 调用 generate_3d_viewer 生成预览页面
→ 获得预览页面: https://domain.com/3d-pages/xyz789.html
3. 返回给用户可访问的链接
完整工作流
# 1. 上传 GLB 文件
s3_upload_file({
fileName: "awesome-model.glb",
fileData: "<base64_data>"
})
# 2. 生成预览页面
generate_3d_viewer({
modelUrl: "返回的URL",
title: "Awesome 3D Model"
})
# 3. 分享预览页面链接
🌍 支持的 S3 兼容存储
- ✅ Cloudflare R2 - 免费 10GB 存储,无流量费用
- ✅ AWS S3 - 业界标准
- ✅ MinIO - 自托管方案
- ✅ DigitalOcean Spaces - 简单易用
- ✅ Backblaze B2 - 低成本
- ✅ 阿里云 OSS - 支持 S3 兼容模式
- ✅ 腾讯云 COS - 支持 S3 兼容模式
🔐 安全配置
Cloudflare R2 自定义域名(推荐)
- 在 R2 Bucket 设置中绑定自定义域名
- 配置
S3_PUBLIC_URL环境变量 - 文件将通过自定义域名公开访问
AWS S3 公开访问
- 配置 Bucket Policy 允许公开读取
- 或使用预签名 URL(
s3_get_presigned_url)
📚 技术栈
- Framework: Next.js 14 + App Router
- Storage: AWS SDK S3 Client (支持所有 S3 兼容存储)
- Protocol: Model Context Protocol (MCP)
- Deployment: Vercel
🐛 故障排除
上传失败:403 Forbidden
- 检查 Access Key 和 Secret Key 是否正确
- 确认 Bucket 存在且有写入权限
文件无法访问
- 配置 S3_PUBLIC_URL 环境变量
- 或使用
s3_get_presigned_url生成临时链接
部署失败
- 确保在 Vercel 项目设置中添加了所有环境变量
- 查看 Vercel 部署日志定位问题
📖 相关文档
🎯 为什么选择 S3 兼容存储?
- 灵活性: 可以随时切换存储提供商
- 成本: Cloudflare R2 提供免费额度,无流量费用
- 简单: 标准 S3 API,易于集成
- 可靠: 业界标准,久经考验
- 功能强大: 支持预签名 URL、元数据、生命周期管理等
📝 开发路线图
- [ ] 支持多文件批量上传
- [ ] 添加文件删除功能
- [ ] 支持文件夹管理
- [ ] 集成 CDN 加速
- [ ] 添加使用统计
推荐服务器
Baidu Map
百度地图核心API现已全面兼容MCP协议,是国内首家兼容MCP协议的地图服务商。
Playwright MCP Server
一个模型上下文协议服务器,它使大型语言模型能够通过结构化的可访问性快照与网页进行交互,而无需视觉模型或屏幕截图。
Magic Component Platform (MCP)
一个由人工智能驱动的工具,可以从自然语言描述生成现代化的用户界面组件,并与流行的集成开发环境(IDE)集成,从而简化用户界面开发流程。
Audiense Insights MCP Server
通过模型上下文协议启用与 Audiense Insights 账户的交互,从而促进营销洞察和受众数据的提取和分析,包括人口统计信息、行为和影响者互动。
VeyraX
一个单一的 MCP 工具,连接你所有喜爱的工具:Gmail、日历以及其他 40 多个工具。
graphlit-mcp-server
模型上下文协议 (MCP) 服务器实现了 MCP 客户端与 Graphlit 服务之间的集成。 除了网络爬取之外,还可以将任何内容(从 Slack 到 Gmail 再到播客订阅源)导入到 Graphlit 项目中,然后从 MCP 客户端检索相关内容。
Kagi MCP Server
一个 MCP 服务器,集成了 Kagi 搜索功能和 Claude AI,使 Claude 能够在回答需要最新信息的问题时执行实时网络搜索。
e2b-mcp-server
使用 MCP 通过 e2b 运行代码。
Neon MCP Server
用于与 Neon 管理 API 和数据库交互的 MCP 服务器
Exa MCP Server
模型上下文协议(MCP)服务器允许像 Claude 这样的 AI 助手使用 Exa AI 搜索 API 进行网络搜索。这种设置允许 AI 模型以安全和受控的方式获取实时的网络信息。