zotero-bridge
v1.1.7
Published
ZoteroBridge - MCP Server for Zotero SQLite Database Integration
Downloads
1,620
Maintainers
Readme
ZoteroBridge
📚 概述
ZoteroBridge 是一个模型上下文协议 (MCP) 服务器,可直接连接到 Zotero 的 SQLite 数据库 (zotero.sqlite),让 AI 助手(如 Claude、ChatGPT、GitHub Copilot 等)能够与您的 Zotero 文献库进行交互。
✨ 主要特性
- 🗂️ 文件夹管理 - 创建、重命名、移动和删除 Zotero 文件夹(集合)
- 🏷️ 标签管理 - 为文献添加、删除和查询标签
- 📖 条目操作 - 搜索条目、获取详情、管理文件夹关系
- 📝 内容管理 - 读取/设置摘要,添加笔记
- 📄 PDF 处理 - 提取全文、生成摘要、全文搜索、获取标注
- 🔍 标识符搜索 - 通过 DOI、ISBN、PMID、arXiv、URL 查找文献
- 🔗 相关条目 - 查找手动关联、共享标签/作者的相似文献
- 🛠️ 库维护 - 查找重复项、验证附件、清理孤立记录、合并条目
📋 更新日志
v1.1.7 (2026-02-01)
📁 添加文章到子分类时自动保留在父分类
- ✅
addItemToCollection现在默认同时添加到所有祖先分类 - ✅ 文章添加到子分类时,父分类中的文章不会消失
- ✅ 新增
addToAncestors参数,可选择只添加到目标分类(设为false) - ✅ 新增
getAllAncestorCollectionIDs()内部方法获取所有祖先分类
v1.1.6 (2026-02-01)
📁 父分类自动包含子分类文章
- ✅
getCollectionItems现在默认递归获取所有子分类的文章 - ✅ 查询父分类时自动包含所有后代分类中的条目
- ✅ 结果自动去重(同一条目不会重复出现)
- ✅ 新增
includeSubcollections参数,可选择只获取直接条目(设为false)
v1.1.5 (2026-02-01)
🗑️ 回收站识别功能
- ✅ 所有查询函数现在正确排除
deletedItems表中的条目 - ✅
getItemDetails新增isDeleted和dateDeleted字段 - ✅
findItemByDOI/ISBN/Identifier自动跳过回收站中的条目 - ✅ 新增
isItemDeleted()方法检查条目是否在回收站 - ✅ 新增
getDeletedItems()方法获取回收站内容 - ✅ 新增
getDeletedItemsCount()方法获取回收站条目数量 - ✅ 附件查询也排除已删除的附件
v1.1.3 (2026-02-01)
🔧 修复
- ✅ 修复了集合(文件夹)创建功能 - 添加了必需的
clientDateModified字段 - ✅ 修复了集合重命名功能 - 正确更新
clientDateModified时间戳 - ✅ 修复了集合移动功能 - 确保父子关系正确建立
- ✅ 所有集合操作现在完全符合 Zotero 官方数据库规范
现在可以正常使用:
- 创建新集合(顶级文件夹)
- 创建子集合(支持多层嵌套)
- 重命名集合
- 移动集合到其他父集合
- 获取子集合列表
v1.1.2
- 改进数据库连接稳定性
- 优化错误处理机制
v1.1.0
- 将 42 个工具整合为 13 个基于动作的工具
- 简化接口同时保持全部功能
�🚀 快速开始
前置要求
- Node.js 18.0 或更高版本
- Zotero 7.0 或更高版本
- 支持 MCP 的 AI 客户端(如 Claude Desktop、Cursor、VS Code Copilot)
安装方式
方式一:通过 npm 全局安装(推荐)
npm install -g zotero-bridge方式二:从源码构建
# 克隆仓库
git clone https://github.com/Combjellyshen/ZoteroBridge.git
cd ZoteroBridge
# 安装依赖
npm install
# 构建项目
npm run build配置 AI 客户端
Claude Desktop
添加到 Claude Desktop 配置文件:
Windows: %APPDATA%\Claude\claude_desktop_config.json
macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
{
"mcpServers": {
"zotero-bridge": {
"command": "npx",
"args": ["-y", "zotero-bridge"],
"env": {}
}
}
}如果从源码构建:
{
"mcpServers": {
"zotero-bridge": {
"command": "node",
"args": ["path/to/ZoteroBridge/dist/index.js"],
"env": {}
}
}
}Cursor IDE
在项目根目录创建 .cursor/mcp.json:
{
"mcpServers": {
"zotero-bridge": {
"command": "npx",
"args": ["-y", "zotero-bridge"]
}
}
}VS Code Copilot
- 打开 VS Code 设置 (
Ctrl+,) - 搜索
github.copilot.chat.mcpServers - 点击 "在 settings.json 中编辑"
- 添加以下配置:
"github.copilot.chat.mcpServers": {
"zotero-bridge": {
"command": "npx",
"args": ["-y", "zotero-bridge"]
}
}自定义数据库路径
如果您的 Zotero 数据库不在默认位置:
{
"mcpServers": {
"zotero-bridge": {
"command": "npx",
"args": ["-y", "zotero-bridge", "--db", "D:/MyZotero/zotero.sqlite"]
}
}
}🛠️ 可用工具(13 个整合工具)
v1.1.0+ 版本将原有 42 个工具整合为 13 个基于动作的工具,简化了接口同时保持全部功能。
manage_collection - 文件夹管理
管理 Zotero 文件夹(集合)的所有操作。
| 动作 | 描述 |
|------|------|
| list | 列出所有文件夹 |
| get | 获取文件夹详情 |
| create | 创建新文件夹 |
| rename | 重命名文件夹 |
| move | 移动文件夹到新父级 |
| delete | 删除文件夹 |
| get_subcollections | 获取子文件夹 |
| add_item | 将条目添加到文件夹 |
| remove_item | 从文件夹移除条目 |
| get_items | 获取文件夹中的所有条目 |
manage_tags - 标签管理
管理标签的所有操作。
| 动作 | 描述 |
|------|------|
| list | 列出所有标签 |
| get_item_tags | 获取条目的所有标签 |
| add | 为条目添加标签 |
| remove | 从条目移除标签 |
| create | 创建新标签 |
search_items - 搜索条目
按标题搜索 Zotero 条目。
get_item_details - 获取条目详情
通过 ID 或 Key 获取条目的详细信息。
manage_item_content - 内容管理
管理条目的摘要和笔记。
| 动作 | 描述 |
|------|------|
| get_abstract | 获取条目摘要 |
| set_abstract | 设置条目摘要 |
| get_notes | 获取条目笔记 |
| add_note | 为条目添加笔记 |
manage_pdf - PDF 操作
PDF 文件的各种操作。
| 动作 | 描述 |
|------|------|
| extract_text | 从 PDF 提取全文 |
| get_summary | 获取 PDF 摘要信息 |
| list | 获取条目的 PDF 附件列表 |
| search | 在 PDF 中搜索文本 |
| generate_abstract | 从 PDF 内容生成摘要 |
find_by_identifier - 标识符搜索
通过各种标识符查找文献,支持自动检测。
| 类型 | 描述 |
|------|------|
| doi | 通过 DOI 查找 |
| isbn | 通过 ISBN 查找 |
| pmid | 通过 PubMed ID 查找 |
| arxiv | 通过 arXiv ID 查找 |
| url | 通过 URL 查找 |
| auto | 自动检测标识符类型 |
get_annotations - 获取标注
获取 PDF 标注(高亮、笔记等),支持按类型、颜色筛选或搜索。
search_fulltext - 全文搜索
在 Zotero 全文索引中搜索或获取附件的全文内容。
find_related_items - 查找相关条目
通过多种方式查找相关文献。
| 方法 | 描述 |
|------|------|
| manual | 获取手动关联的条目 |
| tags | 通过共享标签查找 |
| creators | 通过共享作者查找 |
| collection | 在同一文件夹中查找 |
| all | 使用所有方法查找 |
get_database_info - 数据库信息
获取 Zotero 数据库信息(路径、存储位置、统计数据)。
raw_query - 原始 SQL 查询
执行原始 SQL 查询(仅支持 SELECT,只读)。
library_maintenance - 库维护 🆕
维护和清理 Zotero 库的工具。
| 动作 | 描述 |
|------|------|
| find_duplicates | 查找重复条目(按标题、DOI 或 ISBN) |
| validate_attachments | 验证附件文件是否存在 |
| get_valid_attachment | 获取条目的有效附件 |
| find_with_valid_pdf | 查找有有效 PDF 的条目 |
| cleanup_orphans | 清理孤立的附件记录(支持 dry-run) |
| merge_items | 合并重复条目 |
📖 使用示例
与 Claude/Copilot 配合使用
# 搜索文献
搜索标题中包含"深度学习"的条目
# 获取详情
获取 itemID 为 1234 的条目详细信息
# 管理文件夹
创建一个名为"机器学习论文"的新文件夹
将条目 1234 添加到文件夹 5678
# PDF 操作
提取附件 ID 为 100 的 PDF 全文
在这个 PDF 中搜索"neural network"
# 通过 DOI 查找
查找 DOI 为 10.1126/science.aaa2397 的文献
# 获取标注
获取条目 1234 的所有高亮标注
# 库维护
查找我的库中的重复条目
检查条目 1234 的附件是否有效🏗️ 项目结构
ZoteroBridge/
├── src/
│ ├── index.ts # MCP 服务器入口
│ ├── database.ts # Zotero SQLite 数据库操作
│ ├── pdf.ts # PDF 处理模块
│ └── tools.ts # MCP 工具定义(13 个整合工具)
├── dist/ # 编译输出
├── test/ # 测试文件
├── package.json
├── tsconfig.json
└── README.md👨💻 开发指南
开发模式
# 监听文件变化并自动编译
npm run dev构建
npm run build命令行参数
# 显示帮助
zotero-bridge --help
# 指定数据库路径
zotero-bridge --db /path/to/zotero.sqlite
# 只读模式
zotero-bridge --readonly⚠️ 注意事项
- 关闭 Zotero:使用写入功能时,请关闭 Zotero 客户端以避免数据库锁定
- 备份数据:在进行修改前备份
zotero.sqlite - 只读模式:仅读取数据时使用
--readonly参数更安全 - 附件验证:使用
library_maintenance的validate_attachments检查文件是否存在
📝 更新日志
v1.1.4 (2026-02-01)
🔧 重要修复 - 数据库兼容性
- ✅ 修复重复项查询不一致问题 -
findItemByDOI/ISBN现在始终返回最新修改的条目 - ✅ 修复
itemTags.type字段 - 该字段为 NOT NULL,必须提供值 - ✅ 动态获取
note/attachment的 itemTypeID,不再硬编码 - ✅ 所有查询现在排除
deletedItems表中的已删除条目
🚀 新功能
- ✨ 添加事务支持 (
beginTransaction/commitTransaction/rollbackTransaction) - ✨
mergeItems现在使用事务保证数据一致性 - ✨
mergeItems新增附件转移功能 - ✨ 重复项查询现在返回
_duplicateWarning警告信息
🛡️ 安全性改进
- 所有写操作前检查 Zotero 进程状态
- 自动创建数据库备份
- 批量操作使用事务保护
v1.1.2 (2025-02-01)
- 更新所有依赖到最新版本
- 修复 Zod 4.x 兼容性问题
- 修复 pdf-parse 2.x ESM 导入问题
v1.1.1 (2025-02-01)
- 将 42 个工具整合为 13 个基于动作的工具
- 新增
library_maintenance工具(重复检测、附件验证、孤立清理、条目合并)
v1.1.0
- 初始整合版本
📄 许可证
本项目采用 MIT 许可证。
🙏 致谢
- Zotero - 优秀的开源文献管理工具
- Model Context Protocol - AI 工具集成协议
- cookjohn/zotero-mcp - 项目参考
📬 联系方式
- 作者:Combjellyshen
- GitHub:https://github.com/Combjellyshen/ZoteroBridge
- npm:https://www.npmjs.com/package/zotero-bridge
欢迎提交 Issue 或 Pull Request!
