io.github.RaulSimpetru/zotero-library-mcp

编码与调试

by raulsimpetru

可通过 DOI、arXiv ID 或 ISBN 将论文和图书添加到 Zotero,并管理文献库。

什么是 io.github.RaulSimpetru/zotero-library-mcp

可通过 DOI、arXiv ID 或 ISBN 将论文和图书添加到 Zotero,并管理文献库。

README

zotero-library-mcp

An MCP server that lets AI assistants add papers and books to your Zotero library by DOI, arXiv ID, or ISBN — and manage your collections, tags, and items.

Tools

Adding papers

  • add_paper_by_doi — Resolve a DOI via CrossRef and add the paper to Zotero (with duplicate detection)
  • add_papers_by_dois — Batch-add up to 50 papers at once
  • add_paper_by_arxiv_id — Add a preprint by arXiv ID (uses DOI when available, falls back to arXiv metadata)

Adding books

  • add_book_by_isbn — Resolve an ISBN via Open Library and add the book to Zotero (with duplicate detection)

Searching & browsing

  • search_library — Search your Zotero library by title, author, tag, etc. (falls back to fuzzy matching when the exact search returns no results)
  • get_item_details — View full metadata for any item
  • get_recent_items — List recently added items
  • get_unfiled_items — Get items not in any collection

Reading & annotating

  • get_item_fulltext — Get the full text of an indexed PDF
  • get_bibtex — Export BibTeX for one or more items, a collection, or your full library (abstracts stripped by default to save tokens; with optional save_path to write a .bib file directly)
  • get_annotations — List all highlights and annotations on a paper's PDF
  • create_annotation — Highlight a text passage in a PDF (searches for the exact text, creates a visible highlight in Zotero's reader, and returns a preview image for verification). Smart overlap handling: exact duplicates update the existing comment; sub-passages get a contrasting highlight color automatically.
  • add_note — Add a note to an item

File attachments

  • attach_file — Attach a local file to an item
  • download_pdf — Download a PDF attachment to a local file (useful when Zotero's fulltext index is incomplete)

Collections

  • list_collections — List all collections (with nesting)
  • create_collection — Create a new collection (optionally nested under a parent)
  • get_collection_items — Browse items in a collection
  • add_to_collection — Add an existing item to a collection
  • remove_from_collection — Remove an item from a collection (keeps it in your library)

Tags

  • list_tags — List all tags in your library
  • add_tags — Add one or more tags to an item (with optional color)
  • remove_tags — Remove tags from an item
  • delete_tags — Delete tags from the entire library
  • set_tag_color — Assign a color to a tag (appears in Zotero's tag selector)
  • rename_tag — Rename a tag across all items in your library

Verification

  • verify_items — Re-check recent items against CrossRef to catch bad DOIs or title mismatches

Deleting

  • delete_item — Permanently delete an item from your library
  • delete_collection — Permanently delete a collection

Prerequisites

  1. A Zotero account
  2. A Zotero API key with write permissions: https://www.zotero.org/settings/keys
  3. Your Zotero library ID (shown on the same page, or in your profile URL)
  4. uv installed

Quick Start

Claude Code

bash
claude mcp add zotero \
  -e ZOTERO_LIBRARY_ID=your_library_id \
  -e ZOTERO_API_KEY=your_api_key \
  -- uvx --from git+https://github.com/RaulSimpetru/zotero-library-mcp zotero-mcp

WebDAV setup

To use WebDAV file storage (e.g. Synology, Nextcloud), include the WebDAV variables:

bash
claude mcp add zotero \
  -e ZOTERO_LIBRARY_ID=your_library_id \
  -e ZOTERO_API_KEY=your_api_key \
  -e ZOTERO_WEBDAV_URL=https://your-webdav-server.com \
  -e ZOTERO_WEBDAV_USER=your_username \
  -e ZOTERO_WEBDAV_PASSWORD=your_password \
  -- uvx --from git+https://github.com/RaulSimpetru/zotero-library-mcp zotero-mcp

Claude Desktop

Add this to your claude_desktop_config.json:

json
{
  "mcpServers": {
    "zotero": {
      "command": "/full/path/to/uvx",
      "args": ["--from", "git+https://github.com/RaulSimpetru/zotero-library-mcp", "zotero-mcp"],
      "env": {
        "ZOTERO_LIBRARY_ID": "your_library_id",
        "ZOTERO_API_KEY": "your_api_key",
        "ZOTERO_WEBDAV_URL": "https://your-webdav-server.com",
        "ZOTERO_WEBDAV_USER": "your_username",
        "ZOTERO_WEBDAV_PASSWORD": "your_password"
      }
    }
  }
}

Note: Claude Desktop doesn't inherit your shell's PATH, so you need the full path to uvx. Find it with which uvx in your terminal.

Run standalone

bash
ZOTERO_LIBRARY_ID=your_id ZOTERO_API_KEY=your_key \
  uvx --from git+https://github.com/RaulSimpetru/zotero-library-mcp zotero-mcp

Environment Variables

VariableRequiredDescription
ZOTERO_LIBRARY_IDYesYour Zotero user or group library ID
ZOTERO_API_KEYYesAPI key with read/write permissions
ZOTERO_LIBRARY_TYPENouser (default) or group
CROSSREF_MAILTONoYour email for CrossRef polite pool (faster API access)
ZOTERO_WEBDAV_URLNoWebDAV URL for file storage (e.g. https://dav.example.com)
ZOTERO_WEBDAV_USERNoWebDAV username
ZOTERO_WEBDAV_PASSWORDNoWebDAV password

Note: If all three ZOTERO_WEBDAV_* variables are set, file attachments are uploaded to your WebDAV server instead of Zotero's built-in storage. The server automatically appends /zotero to the base URL, matching Zotero Desktop's behavior.

How it works

  1. You provide a DOI, arXiv ID, or ISBN
  2. The server queries the appropriate API to get full metadata:
  3. Metadata is mapped to Zotero's item format (title, authors, journal/publisher, date, etc.)
  4. The item is created in your Zotero library via the Zotero Web API

License

MIT

mcp-name: io.github.RaulSimpetru/zotero-library-mcp

常见问题

io.github.RaulSimpetru/zotero-library-mcp 是什么?

可通过 DOI、arXiv ID 或 ISBN 将论文和图书添加到 Zotero,并管理文献库。

相关 Skills

网页构建器

by anthropics

Universal
热门

面向复杂 claude.ai HTML artifact 开发,快速初始化 React + Tailwind CSS + shadcn/ui 项目并打包为单文件 HTML,适合需要状态管理、路由或多组件交互的页面。

在 claude.ai 里做复杂网页 Artifact 很省心,多组件、状态和路由都能顺手搭起来,React、Tailwind 与 shadcn/ui 组合效率高、成品也更精致。

编码与调试
未扫描123.0k

前端设计

by anthropics

Universal
热门

面向组件、页面、海报和 Web 应用开发,按鲜明视觉方向生成可直接落地的前端代码与高质感 UI,适合做 landing page、Dashboard 或美化现有界面,避开千篇一律的 AI 审美。

想把页面做得既能上线又有设计感,就用前端设计:组件到整站都能产出,难得的是能避开千篇一律的 AI 味。

编码与调试
未扫描123.0k

网页应用测试

by anthropics

Universal
热门

用 Playwright 为本地 Web 应用编写自动化测试,支持启动开发服务器、校验前端交互、排查 UI 异常、抓取截图与浏览器日志,适合调试动态页面和回归验证。

借助 Playwright 一站式验证本地 Web 应用前端功能,调 UI 时还能同步查看日志和截图,定位问题更快。

编码与调试
未扫描123.0k

相关 MCP Server

GitHub

编辑精选

by GitHub

热门

GitHub 是 MCP 官方参考服务器,让 Claude 直接读写你的代码仓库和 Issues。

这个参考服务器解决了开发者想让 AI 安全访问 GitHub 数据的问题,适合需要自动化代码审查或 Issue 管理的团队。但注意它只是参考实现,生产环境得自己加固安全。

编码与调试
84.2k

by Context7

热门

Context7 是实时拉取最新文档和代码示例的智能助手,让你告别过时资料。

它能解决开发者查找文档时信息滞后的问题,特别适合快速上手新库或跟进更新。不过,依赖外部源可能导致偶尔的数据延迟,建议结合官方文档使用。

编码与调试
53.3k

by tldraw

热门

tldraw 是让 AI 助手直接在无限画布上绘图和协作的 MCP 服务器。

这解决了 AI 只能输出文本、无法视觉化协作的痛点——想象让 Claude 帮你画流程图或白板讨论。最适合需要快速原型设计或头脑风暴的开发者。不过,目前它只是个基础连接器,你得自己搭建画布应用才能发挥全部潜力。

编码与调试
46.4k

评论