Skip to main content
Glama
TencentCloudADP-DevRel

S3-Compatible 3D Storage MCP Server

🎨 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_ENDPOINTR2_ACCESS_KEY_IDR2_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 自定义域名(推荐)

  1. 在 R2 Bucket 设置中绑定自定义域名

  2. 配置 S3_PUBLIC_URL 环境变量

  3. 文件将通过自定义域名公开访问

AWS S3 公开访问

  1. 配置 Bucket Policy 允许公开读取

  2. 或使用预签名 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 兼容存储?

  1. 灵活性: 可以随时切换存储提供商

  2. 成本: Cloudflare R2 提供免费额度,无流量费用

  3. 简单: 标准 S3 API,易于集成

  4. 可靠: 业界标准,久经考验

  5. 功能强大: 支持预签名 URL、元数据、生命周期管理等

📝 开发路线图

  • 支持多文件批量上传

  • 添加文件删除功能

  • 支持文件夹管理

  • 集成 CDN 加速

  • 添加使用统计

-
security - not tested
F
license - not found
-
quality - not tested

Resources

Unclaimed servers have limited discoverability.

Looking for Admin?

If you are the server author, to access and configure the admin panel.

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/TencentCloudADP-DevRel/vercel-blob-mcp-server'

If you have feedback or need assistance with the MCP directory API, please join our Discord server