SiYuan Note MCP Server
Enables AI assistants to interact with SiYuan Note for comprehensive notebook management, document editing, and block-level content operations. It supports advanced features like full-text search and SQL queries via secure API integration.
README
<div align="center">
🧠 思源笔记 MCP 服务器
为 Claude Desktop 提供思源笔记集成的 Model Context Protocol 服务器
🚀 让 AI 助手直接管理您的思源笔记
</div>
📖 项目介绍
思源笔记 MCP 服务器 是一个专为 思源笔记 设计的 Model Context Protocol 服务器实现。通过此服务器,您可以在 Claude Desktop 等支持 MCP 的 AI 客户端中直接操作思源笔记,实现笔记管理、内容搜索、文档编辑等功能的无缝集成。
✨ 主要特性
- 🔗 原生集成 - 在 AI 助手中直接操作思源笔记
- 📚 功能完整 - 支持笔记本、文档、块级操作的全套功能
- 🔍 智能搜索 - 全文检索、SQL 查询、标签搜索等多种搜索方式
- 🛠️ 开发者友好 - TypeScript 编写,提供完整的类型定义和 API 文档
- 📦 简单部署 - 支持 npm、Docker 多种安装方式
- 🔒 安全认证 - 基于 Token 的安全认证机制
🚀 快速开始
📋 环境要求
- Node.js >= 18.0.0
- 思源笔记 正在运行且已开启 API 服务
- Claude Desktop 或其他支持 MCP 的客户端
- 思源笔记 API Token(设置 → 关于 → API token)
📥 安装方式
1. 全局安装(推荐)
# 使用 npm
npm install -g @fromsko/siyuan-mcp-server
# 使用 pnpm
pnpm add -g @fromsko/siyuan-mcp-server
2. 直接使用(无需安装)
npx @fromsko/siyuan-mcp-server
3. Docker 方式
docker pull fromsko/siyuan-mcp-server
⚙️ 快速配置
环境变量设置
| 环境变量 | 必需 | 说明 |
|---|---|---|
SIYUAN_TOKEN |
✅ | 思源笔记 API 令牌,用于身份验证 |
在 Claude Desktop 中配置
在 Claude Desktop 配置文件中添加以下内容:
{
"mcpServers": {
"siyuan": {
"command": "npx",
"args": ["-y", "@fromsko/siyuan-mcp-server"],
"env": {
"SIYUAN_TOKEN": "your-api-token"
}
}
}
}
配置文件位置:
- macOS:
~/Library/Application Support/Claude/claude_desktop_config.json - Windows:
%APPDATA%\Claude\claude_desktop_config.json
命令行直接使用
# 全局安装后直接使用
SIYUAN_TOKEN=your-token siyuan-mcp-server
# 使用 npx(无需安装)
SIYUAN_TOKEN=your-token npx @fromsko/siyuan-mcp-server
# Docker 运行
docker run --rm -i \
-e SIYUAN_TOKEN=your-token \
fromsko/siyuan-mcp-server
📚 功能与使用
🔧 可用工具
本 MCP 服务器提供以下核心功能:
| 功能类别 | 描述 | 主要命令 |
|---|---|---|
| 📓 笔记本管理 | 创建、删除、重命名笔记本 | notebook.* |
| 📄 文档操作 | 创建、编辑、删除文档 | filetree.* |
| 🧱 块级操作 | 插入、更新、删除内容块 | block.* |
| 🔍 搜索功能 | 全文搜索、SQL 查询 | search.* |
| 📋 模板系统 | 模板创建和渲染 | template.* |
| 📊 数据查询 | 复杂数据库查询 | sql.* |
💡 使用示例
1. 创建新笔记本
{
"type": "executeCommand",
"params": {
"type": "notebook.createNotebook",
"params": {
"name": "AI 学习笔记"
}
}
}
2. 全文搜索内容
{
"type": "executeCommand",
"params": {
"type": "search.fullTextSearch",
"params": {
"query": "机器学习",
"method": 0
}
}
}
3. 创建带内容的文档
{
"type": "executeCommand",
"params": {
"type": "filetree.createDocWithMd",
"params": {
"notebook": "notebook-id",
"path": "/今日学习总结",
"markdown": "# 今日学习总结\n\n## 主要收获\n\n1. 学习了...\n2. 理解了..."
}
}
}
🆘 获取帮助
获取特定命令的详细帮助信息:
{
"type": "help",
"params": {
"type": "notebook.createNotebook"
}
}
🔧 开发指南
本地开发环境搭建
# 克隆项目
git clone https://github.com/fromsko/siyuan-mcp-server.git
cd siyuan-mcp-server
# 安装依赖
pnpm install
# 开发模式启动
SIYUAN_TOKEN=your-token pnpm dev
# 构建生产版本
pnpm build
# 运行测试
pnpm test
技术栈与要求
- 运行时: Node.js >= 18.0.0
- 语言: TypeScript >= 5.0.0
- 包管理: pnpm(推荐)或 npm
- 框架: @modelcontextprotocol/sdk
- 构建工具: TypeScript Compiler
Docker 开发
# 构建开发镜像
docker build -t siyuan-mcp-server:dev .
# 运行开发容器
docker run --rm -it \
-e SIYUAN_TOKEN=your-token \
-v $(pwd):/app \
siyuan-mcp-server:dev
🐛 问题排查
常见问题解答
❓ 服务器启动失败,提示"缺少 SIYUAN_TOKEN"
请确保正确设置了
SIYUAN_TOKEN环境变量。获取方式:思源笔记 → 设置 → 关于 → API token
❓ 无法连接到思源笔记
请检查以下几点:
- 思源笔记是否正在运行
- API 服务是否已开启(默认端口 6806)
- Token 是否正确且未过期
- 防火墙是否阻止了连接
❓ Claude Desktop 无法识别 MCP 服务器
请尝试以下解决方案:
- 检查配置文件 JSON 格式是否正确
- 重启 Claude Desktop 应用
- 查看 Claude Desktop 日志获取详细错误信息
- 确认 npx 命令可以正常执行
❓ 命令执行失败或返回错误
- 确认思源笔记中存在相应的笔记本或文档
- 检查 Token 权限是否足够
- 查看服务器日志获取详细错误信息
调试模式
启用详细的调试日志:
DEBUG=siyuan-mcp:* SIYUAN_TOKEN=your-token siyuan-mcp-server
日志分析
服务器会输出以下类型的日志:
INFO: 一般信息,如服务启动、连接状态WARN: 警告信息,如参数错误、连接异常ERROR: 错误信息,如 API 调用失败、认证失败
🤝 贡献指南
我们热烈欢迎社区贡献!您可以通过以下方式参与:
如何贡献
- Fork 项目 - 点击右上角的 Fork 按钮
- 创建分支 -
git checkout -b feature/awesome-feature - 提交代码 -
git commit -am 'Add awesome feature' - 推送分支 -
git push origin feature/awesome-feature - 创建 PR - 在 GitHub 上创建 Pull Request
开发规范
- 代码风格: 遵循 TypeScript 严格模式
- 测试覆盖: 为新功能编写单元测试
- 文档更新: 更新相关的 API 文档和使用说明
- 提交规范: 使用清晰的 commit message
报告问题
发现 Bug 或有改进建议?请通过以下方式报告:
- GitHub Issues
- 详细描述问题的复现步骤
- 提供相关的错误日志和环境信息
📜 开源协议
本项目采用 ISC 协议开源,详情请查看 LICENSE 文件。
🔗 相关资源
官方链接
社区与支持
❤️ 特别感谢
- 🌟 原始项目作者 onigeya - 本项目基于其优秀的开源工作进行改进和扩展
- 🙏 思源笔记 团队 - 提供优秀的笔记软件
- 🤖 Anthropic - 推动 MCP 协议发展
- 👥 所有贡献者和用户 - 让项目变得更好
<div align="center">
🌟 如果这个项目对您有帮助,请给我们一个 Star!
<strong>💻 用 TypeScript 和 ❤️ 精心构建</strong>
</div>
推荐服务器
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 模型以安全和受控的方式获取实时的网络信息。