米家 MCP Server
Enables natural language control of Xiaomi smart home devices through MCP, focusing on homes, rooms, device names, and scenes without requiring protocol details.
README
米家 MCP Server
中文文档 | English
一个基于 mijiaAPI 3.x 的产品化米家 MCP 服务。它不再要求客户端先理解 did、siid/piid/aiid 这些协议细节,而是优先面向“家庭、房间、设备名、场景名”提供更自然的查询和控制能力。
这版解决什么问题
- 面向 AI 客户端:优先暴露稳定、清晰的产品级工具,而不是底层协议字段
- 面向真实家庭场景:先看家庭与房间,再定位设备,再执行控制
- 面向 MCP 标准:工具返回结构化结果,服务状态和登录状态可直接被客户端消费
- 面向扩展:标准能力 schema、profile 驱动控制、资源模型可以继续演进
当前能力
服务与登录
get_service_statusprepare_loginreconnect_serviceclear_saved_loginrefresh_devicesget_tool_catalogping
家庭与设备
get_home_overviewlist_homeslist_devicesget_deviceget_device_statusget_device_capabilities
设备控制
control_by_intentcontrol_deviceturn_on_deviceturn_off_deviceset_brightnessset_color_temperatureset_target_temperatureset_hvac_modeset_fan_speedset_cover_position
场景与耗材
list_scenesexecute_sceneget_consumable_items
MCP 资源
mijia://servicemijia://homesmijia://devicesmijia://scenesmijia://capabilitiesmijia://tooling
安装
建议使用 Python 3.10+。
poetry install
如果你不用 Poetry:
pip install -r requirements.txt
启动
poetry run python mcp_server/mcp_server.py
测试握手:
poetry run python mcp_server/mcp_test.py
登录方式
mijiaAPI 3.x 已移除账号密码登录,只支持二维码登录。
首次需要登录时,服务会:
- 生成浏览器页:
~/.miot-mcp/qr.html - 同时生成二维码图片:
~/.miot-mcp/qr.png - 默认优先用系统浏览器打开
qr.html - 只有浏览器打不开时,才回退到图片查看器或终端二维码
认证信息会保存到:
~/.miot-mcp/auth_data.json
推荐登录主路径
- 调用
prepare_login - 调用
get_service_status - 读取
service.qr.page_path或service.qr.image_path - 完成扫码后调用
reconnect_service或直接refresh_devices
登录相关状态
get_service_status 和 mijia://service 都会返回结构化登录状态,重点字段包括:
service.connectedservice.has_saved_loginservice.qr.open_modeservice.qr.page_pathservice.qr.image_pathservice.qr.login_urlassistant_summarynext_steps.should_scan_qr
环境变量
export MIJIA_ENABLE_QR="true"
export MIJIA_QR_OPEN_MODE="browser"
export MIJIA_LOG_LEVEL="INFO"
说明:
MIJIA_ENABLE_QR:是否启用二维码登录,默认trueMIJIA_QR_OPEN_MODE:高级配置,支持browser/viewer/none,默认browserMIJIA_LOG_LEVEL:日志级别,支持DEBUG/INFO/WARNING/ERROR
MCP 客户端配置示例
推荐直接使用虚拟环境里的 Python,而不是 poetry run。
{
"mcpServers": {
"mijia": {
"command": "/path/to/venv/bin/python",
"args": [
"/path/to/miot-mcp/mcp_server/mcp_server.py"
],
"env": {
"MIJIA_ENABLE_QR": "true",
"MIJIA_QR_OPEN_MODE": "browser",
"MIJIA_LOG_LEVEL": "INFO"
}
}
}
}
推荐调用路径
对于大多数 AI 客户端,建议优先这样使用:
prepare_loginget_service_statusrefresh_devicesget_home_overviewget_device_statuscontrol_by_intentlist_scenesexecute_scene
如果客户端需要更稳定、更显式的路由,再补充:
list_homeslist_devicesget_deviceget_device_capabilitiescontrol_device
常用工具说明
prepare_login
主动准备二维码登录。默认优先复用已有二维码页;如果需要重新走一轮扫码,可以传 force_reauth=true。
get_service_status
返回服务连接状态、认证文件路径、日志路径、二维码页路径、下一步建议。
get_home_overview
按家庭和房间输出设备总览,适合客户端先理解家庭结构。
get_device_status
查看单个设备当前状态、可用操作和推荐下一步。
get_device_capabilities
返回标准能力 schema 和 profile 驱动控制项,适合需要稳定路由的客户端。
control_by_intent
自然语言式控制入口。适合大多数日常使用场景,例如“把卧室台灯亮度调到 30%”。
control_device
统一结构化控制入口。适合客户端已经知道目标操作和参数时使用。
使用示例
查看服务状态
{
"name": "get_service_status",
"arguments": {}
}
主动准备登录
{
"name": "prepare_login",
"arguments": {
"reopen_qr": true
}
}
刷新设备与房间映射
{
"name": "refresh_devices",
"arguments": {}
}
查看家庭总览
{
"name": "get_home_overview",
"arguments": {}
}
查看单个设备状态
{
"name": "get_device_status",
"arguments": {
"device_name": "吸顶灯",
"room": "客厅"
}
}
查看能力 schema
{
"name": "get_device_capabilities",
"arguments": {
"device_name": "台灯",
"room": "卧室"
}
}
自然语言控制
{
"name": "control_by_intent",
"arguments": {
"query": "把卧室台灯亮度调到30%"
}
}
结构化控制
{
"name": "control_device",
"arguments": {
"operation": "set_color_temperature",
"device_name": "台灯",
"room": "卧室",
"value": 4000
}
}
执行场景
{
"name": "execute_scene",
"arguments": {
"scene_name": "回家模式"
}
}
当前边界
这版 MCP 重点覆盖的是最常见的家庭控制路径:
- 家庭与房间浏览
- 设备定位
- 通用能力控制
- 标准化能力 schema 暴露
- 场景执行
- 耗材查询
已重点覆盖的典型能力包括:
- 开关
- 亮度
- 色温
- 目标温度
- 模式
- 风速
- 开合位置
更底层、更强定制的能力仍然可以继续往 control_device 扩展,但不再作为默认使用方式对外暴露。
代码结构
当前服务内部主要有三层:
adapter/负责与mijiaAPI交互、登录、设备发现和二维码登录体验mcp_server/core/负责结果封装、能力计算、意图路由、标准化mcp_server/device_definitions/与mcp_server/device_resources/负责标准能力定义、意图定义和产品化资源模型
当前能力和路由不依赖插件自动发现,而是显式导入定义表。这样更清晰,也更适合 AI 客户端稳定调用。
推荐服务器
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 模型以安全和受控的方式获取实时的网络信息。