MCP QuickJS Runner

MCP QuickJS Runner

在沙盒化的 QuickJS WASM 环境中安全地执行任意 JavaScript 代码,允许语言模型或其他 MCP 客户端安全地运行 JavaScript 代码片段,而不会危及主机系统。

Category
访问服务器

README

MCP QuickJS 运行器

一个实现了模型上下文协议 (MCP) 的服务器,它提供了一个工具,可以在编译为 WebAssembly (WASM) 的 QuickJS 引擎中安全地执行任意 JavaScript 代码,并使用 Node.js 内置的 WASI 实现来运行。

描述

此服务器充当 MCP 工具提供程序。它公开了一个名为 run_javascript_code 的工具,该工具接受一个 JavaScript 代码字符串作为输入。然后,该代码在沙盒化的 QuickJS WASM 环境中执行。服务器捕获执行的标准输出 (stdout) 和标准错误 (stderr) 流,并将它们以及任何执行错误返回给 MCP 客户端。

这允许语言模型或其他 MCP 客户端安全地执行可能不受信任的 JavaScript 代码片段,而不会危及主机系统。

特性

  • 安全执行: 使用 QuickJS 和 Node.js WASI 在 WASM 沙箱中运行 JavaScript。
  • 标准 I/O 捕获: 捕获已执行 JavaScript 代码的 stdoutstderr
  • 错误报告: 报告 QuickJS 的运行时错误和非零退出代码。
  • MCP 集成: 通过 stdio 将功能公开为标准 MCP 工具。
  • 使用 TypeScript 构建: 在开发期间提供类型安全。

工作原理

  1. WASM 模块: 使用预编译的 QuickJS 引擎 (qjs-wasi.wasm),该引擎面向 WebAssembly 系统接口 (WASI)。
  2. Node.js WASI: 利用 Node.js 中的 node:wasi 模块来实例化和运行 WASM 模块。
  3. Stdio 重定向(临时文件): 为了从 WASM 环境捕获 stdoutstderr,服务器目前依赖于与 node:wasi 兼容的标准方法:
    • 使用 node:fs/promisesnode:os 在主机文件系统上创建一个临时目录。
    • 在此目录中打开 stdoutstderr 的临时文件。
    • 这些文件的真实 OS 文件描述符在初始化期间传递给 WASI 实例 (stdout: fd, stderr: fd)。
    • QuickJS WASM 模块将其输出写入这些描述符,这些描述符由 WASI 路由到临时文件。
    • 执行完成后,服务器关闭文件句柄并读取临时文件的内容。
    • 临时目录和文件将被清理。
    • (注意:尝试使用内存管道或虚拟文件系统(如 memfs)均未成功,因为 node:wasi 目前需要真实的 OS 文件描述符用于 stdio。)
  4. MCP 通信: 服务器使用 @modelcontextprotocol/sdk 来监听通过 stdio 发送的 MCP 请求,并根据协议格式化执行结果进行响应。

前提条件

  • Node.js (建议 v23.x 或更高版本,请检查您的特定版本的 node:wasi 兼容性)
  • npmyarn
  • QuickJS WASM 文件 (qjs-wasi.wasm) 必须与编译后的服务器脚本位于同一目录中(例如,相对于 ./dist/server.js./dist/qjs-wasi.wasm)。您可能需要单独获取或编译此文件。

安装

  1. 克隆存储库(如果适用)。
  2. 安装依赖项:
    npm install
    

用法

node server.ts

推荐服务器

Baidu Map

Baidu Map

百度地图核心API现已全面兼容MCP协议,是国内首家兼容MCP协议的地图服务商。

官方
精选
JavaScript
Playwright MCP Server

Playwright MCP Server

一个模型上下文协议服务器,它使大型语言模型能够通过结构化的可访问性快照与网页进行交互,而无需视觉模型或屏幕截图。

官方
精选
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

一个由人工智能驱动的工具,可以从自然语言描述生成现代化的用户界面组件,并与流行的集成开发环境(IDE)集成,从而简化用户界面开发流程。

官方
精选
本地
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

通过模型上下文协议启用与 Audiense Insights 账户的交互,从而促进营销洞察和受众数据的提取和分析,包括人口统计信息、行为和影响者互动。

官方
精选
本地
TypeScript
VeyraX

VeyraX

一个单一的 MCP 工具,连接你所有喜爱的工具:Gmail、日历以及其他 40 多个工具。

官方
精选
本地
graphlit-mcp-server

graphlit-mcp-server

模型上下文协议 (MCP) 服务器实现了 MCP 客户端与 Graphlit 服务之间的集成。 除了网络爬取之外,还可以将任何内容(从 Slack 到 Gmail 再到播客订阅源)导入到 Graphlit 项目中,然后从 MCP 客户端检索相关内容。

官方
精选
TypeScript
Kagi MCP Server

Kagi MCP Server

一个 MCP 服务器,集成了 Kagi 搜索功能和 Claude AI,使 Claude 能够在回答需要最新信息的问题时执行实时网络搜索。

官方
精选
Python
e2b-mcp-server

e2b-mcp-server

使用 MCP 通过 e2b 运行代码。

官方
精选
Neon MCP Server

Neon MCP Server

用于与 Neon 管理 API 和数据库交互的 MCP 服务器

官方
精选
Exa MCP Server

Exa MCP Server

模型上下文协议(MCP)服务器允许像 Claude 这样的 AI 助手使用 Exa AI 搜索 API 进行网络搜索。这种设置允许 AI 模型以安全和受控的方式获取实时的网络信息。

官方
精选