
Windows MCP.Net
STDIO.NET-based Windows desktop automation MCP server for AI assistants
.NET-based Windows desktop automation MCP server for AI assistants
English | 中文
一个基于 .NET 的 Windows 桌面自动化 MCP (Model Context Protocol) 服务器,为 AI 助手提供与 Windows 桌面环境交互的能力。
重要提示: 本项目需要 .NET 10 才能运行,请先确保你的本地安装了 .NET 10。如果尚未安装,请访问 .NET 10 下载页面 进行下载和安装。
在您的 MCP 客户端配置中添加以下配置:
{ "mcpServers": { "WindowsMCP.Net": { "type": "stdio", "command": "dnx", "args": ["WindowsMCP.Net@", "--yes"], "env": {} } } }
方式一:工作区配置
在项目根目录创建 .vscode/mcp.json
文件:
{ "mcpServers": { "Windows-MCP.Net-Dev": { "type": "stdio", "command": "dotnet", "args": ["run", "--project", "src/Windows-MCP.Net.csproj"], "cwd": "${workspaceFolder}", "env": {} } } }
方式二:用户配置
通过VS Code命令面板运行 MCP: Open User Configuration
,添加:
{ "mcpServers": { "Windows-MCP.Net-Local": { "type": "stdio", "command": "dotnet", "args": ["run", "--project", "src/Windows-MCP.Net.csproj"], "env": {} } } }
注意: 使用项目源码方式便于开发调试,修改代码后无需重新安装即可生效。VS Code 1.102+ 版本支持MCP服务器的自动发现和管理。
dotnet tool install --global WindowsMCP.Net
# 克隆仓库 git clone https://github.com/AIDotNet/Windows-MCP.Net.git cd Windows-MCP.Net # 构建项目 dotnet build # 运行项目 dotnet run --project src/Windows-MCP.Net.csproj
配置完成后,重启您的MCP客户端,即可开始使用Windows桌面自动化功能!
工具名称 | 功能描述 |
---|---|
LaunchTool | 从开始菜单启动应用程序 |
PowershellTool | 执行 PowerShell 命令并返回状态码 |
StateTool | 捕获桌面状态信息,包括应用程序和UI元素 |
ClipboardTool | 剪贴板复制和粘贴操作 |
ClickTool | 鼠标点击操作(支持左键、右键、中键,单击、双击、三击) |
TypeTool | 在指定坐标输入文本,支持清除和回车 |
ResizeTool | 调整窗口大小和位置 |
SwitchTool | 切换到指定应用程序窗口 |
ScrollTool | 在指定坐标或当前鼠标位置滚动 |
DragTool | 从源坐标拖拽到目标坐标 |
MoveTool | 移动鼠标光标到指定坐标 |
ShortcutTool | 执行键盘快捷键组合 |
KeyTool | 按下单个键盘按键 |
WaitTool | 暂停执行指定秒数 |
ScrapeTool | 抓取网页内容并转换为Markdown格式 |
ScreenshotTool | 截取屏幕并保存到临时目录,返回图片路径 |
OpenBrowserTool | 在默认浏览器中打开指定URL |
工具名称 | 功能描述 |
---|---|
ReadFileTool | 读取指定文件的内容 |
WriteFileTool | 向文件写入内容 |
CreateFileTool | 创建新文件并写入指定内容 |
CopyFileTool | 复制文件到指定位置 |
MoveFileTool | 移动或重命名文件 |
DeleteFileTool | 删除指定文件 |
GetFileInfoTool | 获取文件信息(大小、创建时间等) |
ListDirectoryTool | 列出目录中的文件和子目录 |
CreateDirectoryTool | 创建新目录 |
DeleteDirectoryTool | 删除目录及其内容 |
SearchFilesTool | 在指定目录中搜索文件 |
工具名称 | 功能描述 |
---|---|
ExtractTextFromScreenTool | 使用OCR从整个屏幕提取文字 |
ExtractTextFromRegionTool | 使用OCR从屏幕指定区域提取文字 |
FindTextOnScreenTool | 使用OCR在屏幕上查找指定文字 |
GetTextCoordinatesTool | 获取屏幕上文字的坐标位置 |
ExtractTextFromFileTool | 使用OCR从图像文件中提取文字 |
工具名称 | 功能描述 |
---|---|
FindElementByTextTool | 通过文本内容查找UI元素 |
FindElementByClassNameTool | 通过类名查找UI元素 |
FindElementByAutomationIdTool | 通过自动化ID查找UI元素 |
GetElementPropertiesTool | 获取指定坐标元素的属性信息 |
WaitForElementTool | 等待指定元素出现在界面上 |
工具名称 | 功能描述 |
---|---|
BrightnessTool | 调节屏幕亮度,支持增减和设置具体百分比 |
VolumeTool | 调节系统音量,支持增减和设置具体百分比 |
ResolutionTool | 设置屏幕分辨率(高、中、低三档) |
通过 TypeTool 在记事本中自动输入文本:
使用 ScrapeTool 打开并搜索网页内容:
完整的桌面自动化操作演示:
src/
├── Windows-MCP.Net/ # 主项目
│ ├── .mcp/ # MCP 服务器配置
│ │ └── server.json # 服务器配置文件
│ ├── Exceptions/ # 自定义异常类(待扩展)
│ ├── Interface/ # 服务接口定义
│ │ ├── IDesktopService.cs # 桌面服务接口
│ │ ├── IFileSystemService.cs # 文件系统服务接口
│ │ └── IOcrService.cs # OCR服务接口
│ ├── Models/ # 数据模型(待扩展)
│ ├── Prompts/ # 提示模板(待扩展)
│ ├── Services/ # 核心服务实现
│ │ ├── DesktopService.cs # 桌面操作服务
│ │ ├── FileSystemService.cs # 文件系统服务
│ │ └── OcrService.cs # OCR服务
│ ├── Tools/ # MCP 工具实现
│ │ ├── Desktop/ # 桌面操作工具
│ │ │ ├── ClickTool.cs # 点击工具
│ │ │ ├── ClipboardTool.cs # 剪贴板工具
│ │ │ ├── DragTool.cs # 拖拽工具
│ │ │ ├── GetWindowInfoTool.cs # 窗口信息工具
│ │ │ ├── KeyTool.cs # 按键工具
│ │ │ ├── LaunchTool.cs # 启动应用工具
│ │ │ ├── MoveTool.cs # 鼠标移动工具
│ │ │ ├── OpenBrowserTool.cs # 浏览器打开工具
│ │ │ ├── PowershellTool.cs # PowerShell执行工具
│ │ │ ├── ResizeTool.cs # 窗口调整工具
│ │ │ ├── ScrapeTool.cs # 网页抓取工具
│ │ │ ├── ScreenshotTool.cs # 截图工具
│ │ │ ├── ScrollTool.cs # 滚动工具
│ │ │ ├── ShortcutTool.cs # 快捷键工具
│ │ │ ├── StateTool.cs # 桌面状态工具
│ │ │ ├── SwitchTool.cs # 应用切换工具
│ │ │ ├── TypeTool.cs # 文本输入工具
│ │ │ ├── UIElementTool.cs # UI元素操作工具
│ │ │ └── WaitTool.cs # 等待工具
│ │ ├── FileSystem/ # 文件系统工具
│ │ │ ├── CopyFileTool.cs # 文件复制工具
│ │ │ ├── CreateDirectoryTool.cs # 目录创建工具
│ │ │ ├── CreateFileTool.cs # 文件创建工具
│ │ │ ├── DeleteDirectoryTool.cs # 目录删除工具
│ │ │ ├── DeleteFileTool.cs # 文件删除工具
│ │ │ ├── GetFileInfoTool.cs # 文件信息工具
│ │ │ ├── ListDirectoryTool.cs # 目录列表工具
│ │ │ ├── MoveFileTool.cs # 文件移动工具
│ │ │ ├── ReadFileTool.cs # 文件读取工具
│ │ │ ├── SearchFilesTool.cs # 文件搜索工具
│ │ │ └── WriteFileTool.cs # 文件写入工具
│ │ └── OCR/ # OCR识别工具
│ │ ├── ExtractTextFromRegionTool.cs # 区域文本提取工具
│ │ ├── ExtractTextFromScreenTool.cs # 屏幕文本提取工具
│ │ ├── FindTextOnScreenTool.cs # 屏幕文本查找工具
│ │ └── GetTextCoordinatesTool.cs # 文本坐标获取工具
│ ├── Program.cs # 程序入口点
│ └── Windows-MCP.Net.csproj # 项目文件
└── Windows-MCP.Net.Test/ # 测试项目
├── DesktopToolsExtendedTest.cs # 桌面工具扩展测试
├── FileSystemToolsExtendedTest.cs # 文件系统工具扩展测试
├── OCRToolsExtendedTest.cs # OCR工具扩展测试
├── ToolTest.cs # 工具基础测试
├── UIElementToolTest.cs # UI元素工具测试
└── Windows-MCP.Net.Test.csproj # 测试项目文件
项目使用 Serilog 进行日志记录,日志文件保存在 logs/
目录下:
变量名 | 描述 | 默认值 |
---|---|---|
ASPNETCORE_ENVIRONMENT | 运行环境 | Production |
本项目基于 MIT 许可证开源。详情请参阅 LICENSE 文件。
我们欢迎社区贡献!如果您想为项目做出贡献,请遵循以下步骤:
克隆仓库
git clone https://github.com/AIDotNet/Windows-MCP.Net.git cd Windows-MCP.Net
安装依赖
dotnet restore
运行测试
dotnet test
构建项目
dotnet build
git checkout -b feature/AmazingFeature
)git commit -m 'Add some AmazingFeature'
)git push origin feature/AmazingFeature
)在报告问题时,请提供:
如果您遇到问题或有建议,请:
注意: 本工具需要适当的 Windows 权限来执行桌面自动化操作。请确保在受信任的环境中使用。
免责声明: 使用本工具进行自动化操作时,请遵守相关法律法规和软件使用协议。开发者不承担因误用工具而产生的任何责任。