# 墨问笔记 MCP 服务器
这是一个基于**模型上下文协议(MCP)**的服务器,用于与墨问笔记软件进行交互。通过此服务器,你可以在支持MCP的应用(如Cursor、Claude Desktop等)中直接创建、编辑和管理墨问笔记。
本项目由一支烟花社区和墨问合作共创。
## 🆕 免安装版上线了(小白可用)
### 使用方法(windows为例)
1. 下载mowen-mcp-server-windows-x64-v1.0.0.zip并解压出mowen-mcp-server.exe
2. mcp客户端中修改command值,替换成mowen-mcp-server.exe文件的路径即可
```json
{
"mcpServers": {
"mowen-mcp-server": {
"command": "D:\\mowen\\mowen-mcp-server.exe",
"args": [],
"env": {
"MOWEN_API_KEY": "xxxxxxxxxxxxxxx"
}
}
}
}
```
**✨ 最新版本特性:支持文件上传功能!现在可以在笔记中插入图片、音频和PDF文件,支持本地文件和远程URL两种上传方式。**
## 🆕 新功能预览 (v0.2.0)
### 📁 文件上传支持
⚠️ **重要:文件路径必须使用绝对路径**,因为MCP Server和Client运行在不同的工作目录中。
```python
# 本地图片文件
{
"type": "file",
"file_type": "image",
"source_type": "local",
"source_path": "C:\\Users\\用户名\\Documents\\image.jpg", # Windows绝对路径
"metadata": {
"alt": "图片描述",
"align": "center"
}
}
# 远程音频文件(URL不受路径限制)
{
"type": "file",
"file_type": "audio",
"source_type": "url",
"source_path": "https://example.com/audio.mp3",
"metadata": {
"show_note": "00:00 开始\n01:30 主要内容"
}
}
```
### 📝 引用段落
```python
{
"type": "quote",
"texts": [
{"text": "重要提醒:", "bold": true},
{"text": "支持富文本格式的引用段落"}
]
}
```
### 🔗 内链笔记
```python
{
"type": "note",
"note_id": "VPrWsE_-P0qwrFUOygGs8"
}
```
## 功能特性
- 🔗 **兼容MCP协议**:支持最新的MCP 1.9.1版本
- 📝 **创建笔记**:统一的富文本格式,支持段落、加粗、高亮、链接、引用和内链笔记
- ✏️ **编辑笔记**:统一的富文本格式,完全替换笔记内容
- 📁 **文件上传**:支持图片、音频、PDF文件上传,本地文件和远程URL两种方式
- 💬 **引用段落**:创建引用文本块,支持富文本格式
- 🔗 **内链笔记**:引用其他笔记,创建笔记间的关联
- 🔒 **隐私设置**:设置笔记的公开、私有或规则公开权限
- 🔄 **密钥管理**:重置API密钥功能
- 🎨 **统一接口**:所有笔记操作使用一致的富文本参数格式
## 快速开始
### 前提条件
- Python 3.10+
- 墨问Pro会员账号(API功能仅对Pro会员开放)
- 墨问API密钥(在墨问小程序中获取)
### 安装方式
#### 方式一:从源码安装(推荐)
1. **克隆项目**:
```bash
git clone https://github.com/z4656207/mowen-mcp-server.git
cd mowen-mcp-server
```
2. **安装依赖**:
```bash
pip install -e .
```
#### 方式二:直接安装依赖
```bash
pip install mcp httpx pydantic
```
### 配置 API 密钥
#### Windows PowerShell
```powershell
$env:MOWEN_API_KEY="你的墨问API密钥"
```
#### Linux/macOS
```bash
export MOWEN_API_KEY="你的墨问API密钥"
```
#### 持久化设置
创建 `.env` 文件:
```
MOWEN_API_KEY=你的墨问API密钥
```
### 配置 MCP 客户端
#### 方式一:模块安装方式(推荐)
如果你使用了 `pip install -e .` 安装,在 Cursor 设置中添加:
```json
{
"mcpServers": {
"mowen-mcp-server": {
"command": "python",
"args": ["-m", "mowen_mcp_server.server"],
"env": {
"MOWEN_API_KEY": "${env:MOWEN_API_KEY}"
}
}
}
}
```
#### 方式二:直接文件路径方式
如果你没有安装包,可以直接指定文件路径:
```json
{
"mcpServers": {
"mowen-mcp-server": {
"command": "python",
"args": ["绝对路径/mowen-mcp-server/src/mowen_mcp_server/server.py"],
"env": {
"MOWEN_API_KEY": "${env:MOWEN_API_KEY}"
}
}
}
}
```
**注意**: 请将 `绝对路径` 替换为你的实际项目路径,例如:
- Windows: `"D:/CODE/mowen-mcp-server/src/mowen_mcp_server/server.py"`
- macOS/Linux: `"/home/user/mowen-mcp-server/src/mowen_mcp_server/server.py"`
## 可用工具
### create_note
创建一篇新的墨问笔记,使用统一的富文本格式
**参数:**
- `paragraphs` (数组,必需):富文本段落列表,每个段落包含文本节点
- `auto_publish` (布尔值,可选):是否自动发布,默认为false
- `tags` (字符串数组,可选):笔记标签列表
**支持的段落类型:**
1. **普通段落**(默认):`{"texts": [...]}`
2. **引用段落**:`{"type": "quote", "texts": [...]}`
3. **内链笔记**:`{"type": "note", "note_id": "笔记ID"}`
4. **文件段落**:`{"type": "file", "file_type": "image|audio|pdf", "source_type": "local|url", "source_path": "绝对路径", "metadata": {...}}`
**段落格式示例:**
```json
[
{
"texts": [
{"text": "普通文本"},
{"text": "加粗文本", "bold": true},
{"text": "高亮文本", "highlight": true},
{"text": "链接文本", "link": "https://example.com"}
]
},
{
"type": "quote",
"texts": [
{"text": "这是引用段落"},
{"text": "支持富文本", "bold": true}
]
},
{
"type": "note",
"note_id": "VPrWsE_-P0qwrFUOygxxx"
},
{
"type": "file",
"file_type": "image",
"source_type": "local",
"source_path": "C:\\Users\\用户名\\Documents\\image.jpg",
"metadata": {
"alt": "图片描述",
"align": "center"
}
}
]
```
**简单文本示例:**
```json
[
{
"texts": [
{"text": "这是一段简单的文本内容"}
]
}
]
```
### edit_note
编辑已存在的笔记内容,使用统一的富文本格式
**参数:**
- `note_id` (字符串,必需):要编辑的笔记ID
- `paragraphs` (数组,必需):富文本段落列表,将完全替换原有内容
**注意:** 此操作会完全替换笔记的原有内容,而不是追加内容。支持所有段落类型(普通段落、引用段落、内链笔记、文件段落)。
### set_note_privacy
设置笔记的隐私权限
**参数:**
- `note_id` (字符串):笔记ID
- `privacy_type` (字符串):隐私类型(public/private/rule)
- `no_share` (布尔值,可选):是否禁止分享(仅rule类型有效)
- `expire_at` (整数,可选):过期时间戳(仅rule类型有效,0表示永不过期)
### reset_api_key
重置墨问API密钥
**注意:** 此操作会使当前密钥立即失效
## 使用示例
### 创建简单文本笔记
```python
# 通过MCP工具调用
create_note(
paragraphs=[
{
"texts": [
{"text": "今天学习了Python编程,重点是异步编程概念"}
]
}
],
auto_publish=True,
tags=["学习", "Python", "编程"]
)
```
### 创建富文本笔记
```python
# 通过MCP工具调用
create_note(
paragraphs=[
{
"texts": [
{"text": "重要提醒:", "bold": true},
{"text": "明天的会议已改期"}
]
},
{
"texts": [
{"text": "详情请查看:", "highlight": true},
{"text": "会议通知", "link": "https://example.com/meeting"}
]
}
],
auto_publish=True,
tags=["会议", "通知"]
)
```
### 创建包含引用和内链的复杂笔记
```python
# 通过MCP工具调用
create_note(
paragraphs=[
{
"texts": [
{"text": "项目进展报告", "bold": true}
]
},
{
"type": "quote",
"texts": [
{"text": "本周完成了主要功能开发,", "highlight": true},
{"text": "详见技术文档", "link": "https://docs.example.com"}
]
},
{
"type": "note",
"note_id": "VPrWsE_-P0qwrFUOygGs8"
},
{
"texts": [
{"text": "下周计划:开始测试阶段"}
]
}
],
auto_publish=True,
tags=["项目", "进展", "报告"]
)
```
### 创建包含文件的笔记
```python
# 通过MCP工具调用
create_note(
paragraphs=[
{
"texts": [
{"text": "项目截图和演示", "bold": true}
]
},
{
"type": "file",
"file_type": "image",
"source_type": "local",
"source_path": "C:\\Users\\user\\Desktop\\screenshot.png",
"metadata": {
"alt": "项目主界面截图",
"align": "center"
}
},
{
"texts": [
{"text": "演示视频(音频):"}
]
},
{
"type": "file",
"file_type": "audio",
"source_type": "url",
"source_path": "https://example.com/demo.mp3",
"metadata": {
"show_note": "00:00 项目介绍\n01:30 功能演示\n03:00 总结"
}
},
{
"texts": [
{"text": "详细文档见附件:"}
]
},
{
"type": "file",
"file_type": "pdf",
"source_type": "local",
"source_path": "C:\\Users\\user\\Documents\\project_doc.pdf"
}
],
auto_publish=True,
tags=["项目", "文档", "演示"]
)
```
### 编辑笔记
```python
# 通过MCP工具调用
edit_note(
note_id="note_123456",
paragraphs=[
{
"texts": [
{"text": "更新:", "bold": true},
{"text": "项目进度已完成80%"}
]
},
{
"type": "quote",
"texts": [
{"text": "详细报告请查看:", "highlight": true},
{"text": "项目文档", "link": "https://example.com/report"}
]
},
{
"type": "note",
"note_id": "related_note_id"
}
]
)
```
## API配额限制
根据墨问API文档,各接口有以下限制:
| API | 配额 | 频率限制 | 说明 |
| ---- | -------- | ------ | --------------------------------------- |
| 笔记创建 | 100 次/天 | 1次/秒 | 调用成功才计为 1 次,**即:每天可以基于 API 创建 100 篇笔记** |
| 笔记编辑 | 1000 次/天 | 1次/秒 | 调用成功才计为 1 次,**即:每天可以基于 API 编辑 1000 次** |
| 笔记设置 | 100 次/天 | 1次/秒 | 调用成功才计为 1 次 |
## 项目结构
```
mowen-mcp-server/
├── src/
│ └── mowen_mcp_server/
│ ├── __init__.py # 包初始化
│ ├── server.py # MCP服务器主程序
│ └── config.py # 配置管理
├── examples/
│ └── create_note/ # 创建笔记案例
├── pyproject.toml # 项目配置
├── README.md # 项目文档
├── CHANGELOG.md # 更新日志
└── 墨问API.md # 墨问API详细文档
```
## 相关文档
- **墨问 API 在线文档**: [https://mowen.apifox.cn/](https://mowen.apifox.cn/)
- **本地API文档**: 详细的墨问API文档请参考项目中的 `墨问API.md` 文件
- **MCP协议文档**: [Model Context Protocol](https://modelcontextprotocol.io/)
## 常见问题
### Q: 为什么模块方式运行不起来?
A: 请确保使用 `pip install -e .` 安装了包,或者使用直接文件路径的配置方式。
### Q: API密钥在哪里获取?
A: 登录墨问小程序,在个人主页的开发者模块中找到API密钥,需要Pro会员权限。
### Q: 能编辑小程序创建的笔记吗?
A: 目前不支持,只能编辑通过API创建的笔记。
### Q: 如何使用引用段落和内链笔记?
A: 引用段落使用 `{"type": "quote", "texts": [...]}` 格式,内链笔记使用 `{"type": "note", "note_id": "笔记ID"}` 格式。引用段落支持所有富文本格式(加粗、高亮、链接)。
### Q: 内链笔记的note_id从哪里获取?
A: note_id是创建笔记时返回的笔记ID,或者是墨问中已存在笔记的ID。注意只能引用通过API创建的笔记。
### Q: 为什么只有paragraphs参数,没有简单的content参数?
A: 我们统一了接口设计,使用富文本格式可以支持更丰富的内容。即使是简单文本,也可以很容易地使用paragraphs格式:`[{"texts": [{"text": "你的文本"}]}]`
### Q: 如何从旧版本的API调用迁移?
A: 如果之前使用 `create_note(content="文本")`,现在需要改为 `create_note(paragraphs=[{"texts": [{"text": "文本"}]}])`。富文本功能保持不变。
### Q: 文件上传时为什么提示"文件不存在"?
A: **必须使用绝对路径**。MCP Server和Client运行在不同的工作目录中,相对路径会解析失败。
- ✅ 正确:`"C:\\Users\\用户名\\Documents\\image.jpg"` (Windows)
- ✅ 正确:`"/Users/用户名/Documents/image.jpg"` (macOS/Linux)
- ❌ 错误:`"./image.jpg"` 或 `"image.jpg"` (相对路径)
### Q: 支持哪些文件类型?
A: 支持三种文件类型:
- 图片(image): .gif, .jpeg, .jpg, .png, .webp (最大50MB)
- 音频(audio): .mp3, .mp4, .m4a (最大200MB)
- PDF(pdf): .pdf (最大100MB)
### Q: 远程URL文件上传有什么限制?
A: 远程URL不受路径格式限制,但文件必须公开可访问,且符合文件类型和大小限制。
## 开发贡献
欢迎提交Issue和Pull Request!
### 开发环境设置
1. 克隆项目
2. 安装开发依赖:`pip install -e .`
3. 设置API密钥环境变量
4. 运行测试
## 许可证
本项目采用MIT许可证。详见 [LICENSE](LICENSE) 文件。
## 免责声明
本项目为个人开发的第三方工具,与墨问官方无关。使用前请确保遵守墨问的服务条款。