Xiaoya Teacher MCP Server
小雅教育管理MCP服务器 - 专为教师设计,提供课程资源管理和试题创建工具
Installation
npx xiaoya-teacher-mcp-serverAsk AI about Xiaoya Teacher MCP Server
Powered by Claude · Grounded in docs
I know everything about Xiaoya Teacher MCP Server. Ask me about installation, configuration, usage, or troubleshooting.
0/500
Reviews
Documentation
小雅教育管理MCP服务器
专为教师设计的小雅智能教学平台教育管理 MCP 服务器。通过 MCP 与 AI 助手集成,提供课程资源管理、题目创建、试卷配置、班级查询、签到统计、任务测验与批阅等能力。
默认安装采用精简依赖,适合本地 editable、uv tool 和标准发布包;如需完整文档格式转换能力,可额外安装 full extra。
✨ 核心特性
🎯 AI助手集成
- MCP协议支持 - 完美集成到支持MCP的AI助手(如Claude Desktop、Cursor等)
- 多种传输方式 - 支持stdio、SSE、Streamable HTTP传输协议
- 摘要优先查询 - 题目、资源、任务默认返回摘要, 减少 AI token 消耗
- 统一响应格式 - 标准化的API响应, 便于AI助手解析和展示
📚 智能题库系统
- 7种题型支持 - 单选题、多选题、填空题、判断题、简答题、附件题、编程题
- 富文本编辑 - 支持题目描述的富文本格式(粗体、斜体、下划线、代码块等)
- 智能评分 - 填空题支持多种自动评分策略(精确匹配、部分匹配、有序/无序)
- 批量操作 - 支持批量创建题目、官方导入题目、题目排序调整
📁 资源管理系统
- 多类型资源 - 文件夹、笔记、思维导图、文件、作业、教学设计
- 完整生命周期 - 创建、删除、重命名、移动、排序、权限管理
- 文件处理 - 文件下载、markdown格式转换
- 树形结构 - 清晰的资源层级展示
👥 班级与签到
- 班级管理 - 班级信息查询、学生统计
- 签到系统 - 签到记录查询、学生签到详情、多种签到状态
- 数据统计 - 出勤率分析、签到趋势
📋 任务与测验
- 任务查询 - 查询课程组已发布任务列表、任务详情
- 成绩管理 - 学生答题情况统计、成绩分析
- 答题分析 - 学生答题详情预览、题目解析
- AI 批阅 - 逐题打分、批注、提交批改,支持附件答案(图片/PDF/文件)查看
🚀 快速开始
发布安装
# 使用 uvx 直接运行
uvx xiaoya-teacher-mcp-server
本地开发安装
git clone https://github.com/Sav1ouR520/xiaoya-teacher-mcp-server.git
cd xiaoya-teacher-mcp-server
# 安装开发依赖
uv sync --dev
# 运行服务器
uv run xiaoya-teacher-mcp-server
完整文档转换支持
# 本地开发时启用 full extra
uv sync --dev --extra full
# 发布安装时启用 full extra
pip install "xiaoya-teacher-mcp-server[full]"
本机工具安装
# 将当前仓库安装为本机可执行 MCP 命令
uv tool install -e --reinstall .
⚙️ 配置说明
认证配置
服务器支持两种认证方式,本地(stdio)与远程(SSE/HTTP)均可使用。账号密码模式支持自动登录和 token 缓存;Bearer Token 模式只使用调用方提供的 token。
方式一:账号密码自动登录(推荐,支持多账号远程缓存)
本地(stdio)和远程(SSE/HTTP)均可通过账号密码自动登录,token 会自动缓存,远程多账号也会自动保存。若请求过程中检测到认证过期,服务端会自动重新登录一次并重试当前请求.
{
"mcpServers": {
"xiaoya-teacher-mcp-server": {
"command": "uvx",
"args": ["xiaoya-teacher-mcp-server"],
"env": {
"XIAOYA_ACCOUNT": "your_account",
"XIAOYA_PASSWORD": "your_password"
}
}
}
}
远程请求也支持通过 header 传递账号密码,首次访问自动登录并缓存:
POST /mcp/xxx
X-XIAOYA-ACCOUNT: your_account
X-XIAOYA-PASSWORD: your_password
方式二:Token直接认证
本地和远程均可直接传递 Bearer Token,无需账号密码。该模式不会自动重新登录,若 token 过期需由调用方更新后再重试.
{
"mcpServers": {
"xiaoya-teacher-mcp-server": {
"command": "uvx",
"args": ["xiaoya-teacher-mcp-server"],
"env": {
"XIAOYA_AUTH_TOKEN": "your_bearer_token"
}
}
}
}
远程请求也支持通过 header 传递 Authorization:
Authorization: Bearer your_bearer_token
传输协议配置
标准输入输出(默认)
{
"mcpServers": {
"xiaoya-teacher-mcp-server": {
"command": "uvx",
"args": ["xiaoya-teacher-mcp-server"],
"env": {
"MCP_TRANSPORT": "stdio"
}
}
}
}
服务器发送事件
{
"mcpServers": {
"xiaoya-teacher-mcp-server": {
"command": "uvx",
"args": ["xiaoya-teacher-mcp-server"],
"env": {
"MCP_TRANSPORT": "sse",
"MCP_MOUNT_PATH": "/mcp"
}
}
}
}
Streamable HTTP
{
"mcpServers": {
"xiaoya-teacher-mcp-server": {
"command": "uvx",
"args": ["xiaoya-teacher-mcp-server"],
"env": {
"MCP_TRANSPORT": "streamable-http",
"MCP_MOUNT_PATH": "/mcp"
}
}
}
}
高级配置:多传输同时启用
在需要同时对多种客户端开放 MCP 服务时, 可通过逗号分隔一次性启用多个传输协议.示例:
{
"mcpServers": {
"xiaoya-teacher-mcp-server": {
"command": "uvx",
"args": ["xiaoya-teacher-mcp-server"],
"env": {
"MCP_TRANSPORT": "sse,streamable-http",
"MCP_MOUNT_PATH": "/mcp",
"MCP_HOST": "0.0.0.0",
"MCP_PORT": "8000"
}
}
}
}
此时,远程客户端只需如下配置即可访问(无需本地环境变量,支持自动登录和多账号缓存):
{
"mcpServers": {
"xiaoya-teacher-mcp-sse-server": {
"url": "http://ip:port/mcp/sse",
"headers": {
"x-xiaoya-account": "你的账号",
"x-xiaoya-password": "你的密码"
}
}
}
}
也支持 streamable-http 协议,只需将 url 改为 /mcp 路径。
- MCP_PORT 与 MCP_HOST 为可选项, 用于指定监听地址与端口(仅对基于 HTTP 的传输生效)
- 同时启用 SSE 与 Streamable HTTP 时会复用同一 Uvicorn/Starlette 服务, 客户端可并发使用两种协议
- 所有基于 HTTP 的传输挂载到相同路径, 默认为 http://host:port/mcp/*, 可用 MCP_MOUNT_PATH 调整
- stdio 传输不使用 MCP_HOST/MCP_PORT
📖 使用指南
- 选择认证方式 - 根据您的需求选择账号密码或Token认证
- 配置环境变量 - 在MCP客户端配置文件中设置相应的环境变量
- 集成到AI助手 - 在Claude Desktop、Cursor等支持MCP的AI助手中使用
- 开始教学管理 - 直接与AI对话, 完成题库管理、资源整理、班级管理等任务
常用流程与能力边界
出题/组卷
- 试卷通常对应课程资源中的
ASSIGNMENT作业资源。新建试卷时先用query_course_resources_summary定位目标文件夹,再用create_course_resource(type=ASSIGNMENT)创建资源并取得paper_id。 - 修改已有试卷时,优先从
query_course_resources_summary或query_course_resources中查找带paper_id的作业资源,再用query_paper_summary查看题数、题型和总分。 query_group_tasks面向已发布任务,主要提供paper_id和publish_id给批阅/答题统计流程使用,不负责筛选未发布试卷。- 当前没有单独的“自动生成试卷标题”工具。需要个性化标题时,建议让 AI 先给出候选标题,经老师确认后作为
create_course_resource的资源名称。
批阅/成绩
- 先用
query_group_tasks选择已发布任务,再调用query_test_result获取提交人数、未提交人数、平均分和学生答题记录。 - 查看单个学生答卷使用
query_preview_student_paper;需要完整答案内容时设置detail_level=full。 - 主观题评分流程为
grade_student_question逐题打分,最后用submit_student_mark提交整卷批阅。选择题、判断题、自动评分填空题一般沿用系统判分。 - 附件答案可用
get_answer_file获取 base64 内容;图片/PDF/小文件更适合直接读取,视频或大文件建议谨慎调用,避免返回过大的内容。
编程题
create_code_question的program_setting.in_cases只需要提供输入,格式为[{"in": "输入内容"}]。- 平台会根据参考答案代码运行生成期望输出,不需要在
in_cases里手写out字段。 description用于解析或补充说明,参考答案代码请放在program_setting.code_answer。
批量操作
- 批量创建、批量删除和资源批量更新只有全部成功时顶层
success=true;部分失败时success=false,但data.failed_items会列出未创建/未删除/未更新的条目及原因,data.success_ids会保留已成功的 ID。
🏗️ 项目架构
xiaoya-teacher-mcp-server/
├── pyproject.toml # 打包配置
├── README.md # 项目文档
├── hatch_build.py # Hatchling 打包钩子
├── src/
│ └── xiaoya_teacher_mcp_server/
│ ├── config.py # 配置文件和认证模块
│ ├── field_descriptions.py # MCP 字段描述常量
│ ├── main.py # 服务器入口和传输协议处理
│ ├── tools/ # 核心工具模块
│ │ ├── questions/ # 题目管理工具
│ │ ├── resources/ # 资源管理工具
│ │ ├── group/ # 班级和签到查询
│ │ └── task/ # 任务和测验管理
│ ├── types/ # 类型定义
│ │ ├── enums.py # 通用枚举
│ │ ├── question_models.py # 题目相关模型
│ │ ├── resource_models.py # 资源相关模型
│ │ └── task_models.py # 班课相关模型
│ └── utils/ # 公共工具函数
│ ├── client.py # 统一 HTTP 客户端与自动重登
│ ├── logging.py # 统一日志
│ ├── response.py # 统一响应处理
│ └── rich_text.py # 纯文本与 raw 富文本转换
└── tests/ # 回归测试
核心模块说明
🎯 题目管理模块
- create.py - 完整支持7种题型的创建, 包括复杂的编程题设置
- update.py - 题目内容更新、答案修改、选项管理
- query.py - 默认返回试卷摘要, 按需返回完整明细
- delete.py - 题目和答案项的删除操作
📁 资源管理模块
- create.py - 多类型资源创建(文件夹、笔记、思维导图等)
- update.py - 资源重命名、移动、排序、权限设置
- query.py - 默认返回资源摘要, 支持文件夹局部快照、文件下载、markdown格式转换
- delete.py - 资源文件的删除操作
👥 班级管理模块
- query.py - 班级列表、签到记录、课程组总览查询
📋 任务管理模块
- query.py - 默认返回任务和答题摘要, 按需返回完整答卷明细
- grade.py - 逐题打分与提交批改, 附件答案文件获取
🔧 技术栈
- Python 3.11+ - 主要开发语言
- FastMCP - MCP协议实现框架
- Pydantic - 数据验证和类型定义
- Requests - HTTP客户端
- MarkItDown - 文档格式转换
📄 许可证
本项目采用MIT许可证 - 查看 LICENSE 文件了解详情.
👨💻 作者
Sav1ouR520
- Email: 3300233150@qq.com
- GitHub: https://github.com/Sav1ouR520
