managebac-mcp
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@managebac-mcp查看我的所有截止日期"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
ManageBac MCP 服务器
基于 ManageBac 学生端网页实现
为您的 AI Agent 接入 ManageBac
这是一个本地 stdio MCP 服务器,可以让 Claude Code、OpenCode 等 AI Agent 读取 ManageBac 中的 DDL、class、成绩条目和页面明确显示的 GPA。
默认登录方式是手动浏览器登录:先运行 npm run login,程序会保存 .managebac/storage-state.json,之后 MCP 工具复用这个 session。只有显式设置 MANAGEBAC_LOGIN_MODE=password 时,程序才会尝试自动提交账号密码。
Related MCP server: qldt-hanu-mcp
✨ 功能特性
获取 class / course 列表
从主页
Tasks & Deadlines读取upcoming、past、overdue三个栏目查看全部 DDL,以及查看单科 DDL
查看全部成绩,以及查看某一门 class 的成绩
读取全局 GPA / 单科 GPA;读不到页面明确显示的 GPA 时直接返回 error
禁止按百分制或 IB 1-7 成绩估算非加权 4.0 GPA
读取某一门课近期 N 条成绩
读取某一门课的成绩占比 / category weight
默认手动登录并记录 session,降低账号被锁风险
支持自动密码登录,但必须主动开启
🛠️ 工具列表
managebac_check_session: 确认当前 session 能读取学生首页managebac_get_classes: 获取 class / course 列表managebac_get_all_deadlines: 查看主页 Tasks & Deadlines,可选view: upcoming | past | overdue | allmanagebac_get_class_deadlines: 查看单科 DDLmanagebac_get_grades: 查看全部成绩 / 分数条目managebac_get_class_grades: 获取某一门 class 的成绩managebac_get_gpa: 读取页面明确显示的全局 GPA,读不到时返回 errormanagebac_get_class_gpa: 读取页面明确显示的单科 GPA,读不到时返回 errormanagebac_get_recent_class_grades: 读取这门 class 的近期 N 条成绩managebac_get_class_grade_weights: 读取这门课的成绩占比managebac_list_links: 列出登录后页面链接,用来找到某个 class 的精确路径managebac_debug_snapshot: 返回某页正文和链接,用于调试抓取规则
🚀 安装与使用
快速安装:复制以下命令给 AI agent
请帮我安装并配置 ManageBac MCP:
git clone https://github.com/chiang881/managebac-mcp.git
cd managebac-mcp
npm install
npm run build
npm run deploy
npm run login
然后把这个 MCP server 配置为 stdio:
node /absolute/path/managebac-mcp/dist/index.jsnpm run deploy 会询问 ManageBac 实例地址。不要把默认实例写死成某个学校,请填写自己的实例,例如:
MANAGEBAC_BASE_URL=https://your-school.managebac.com手动安装
git clone https://github.com/chiang881/managebac-mcp.git
cd managebac-mcp
npm install
npm run build如果第一次运行 Playwright 找不到 Chromium:
npm run install-browser复制配置文件:
cp .env.example .env最小配置:
MANAGEBAC_BASE_URL=https://your-school.managebac.com
MANAGEBAC_LOGIN_MODE=manual
MANAGEBAC_STORAGE_STATE=.managebac/storage-state.json保存配置后,打开浏览器手动登录并记录 session:
npm run login自动密码登录
默认不自动提交密码。如果确实需要自动登录,在 .env 或 MCP 客户端 env 中显式设置:
MANAGEBAC_LOGIN_MODE=password
MANAGEBAC_EMAIL=your.email@example.com
MANAGEBAC_PASSWORD=your-password
MANAGEBAC_LOGIN_COOLDOWN_MS=900000
MANAGEBAC_LOGIN_FORCE=false如果账号刚被锁定,先不要反复运行自动登录。确认网页可以手动登录后,运行 npm run login 重新保存 session。
非交互 / headless 部署
npm run deploy 会运行交互式配置向导,非交互环境会报错:
Interactive terminal required. Set MANAGEBAC_BASE_URL and MANAGEBAC_LOGIN_MODE manually in non-interactive deployments.解决方式有两种:
直接编辑
.env,至少写入MANAGEBAC_BASE_URL和MANAGEBAC_LOGIN_MODE=manual在 MCP 客户端配置的
env中传入这些变量
.env、.managebac/storage-state.json 和调试文件已经在 .gitignore 中忽略。不要把账号密码或登录态提交到 GitHub。
Claude Code 配置
Claude Code 的项目 MCP 配置应写在仓库根目录的 .mcp.json,不是 ~/.claude/settings.json:
{
"mcpServers": {
"managebac": {
"command": "node",
"args": ["/absolute/path/managebac-mcp/dist/index.js"],
"env": {
"MANAGEBAC_BASE_URL": "https://your-school.managebac.com",
"MANAGEBAC_LOGIN_MODE": "manual",
"MANAGEBAC_STORAGE_STATE": "/absolute/path/managebac-mcp/.managebac/storage-state.json"
}
}
}
}配置后通常还需要完成 Claude Code 的审批链:
在
.claude/settings.local.json中允许项目 MCP server,例如设置enabledMcpjsonServers,或使用enableAllProjectMcpServers: true重启 Claude Code,让
.mcp.json和权限配置生效重启后运行
/mcp,如果managebac仍处于 pending 状态,手动批准第一次调用每个 MCP tool 时,Claude Code 可能还会要求单独 allow
调试建议
如果 DDL 或 GPA 没抓准,先调用:
managebac_list_links({ "match": "task" })
managebac_list_links({ "match": "grade" })
managebac_debug_snapshot({ "path": "/student/tasks_and_deadlines?view=upcoming" })单科 DDL 位于 Classes -> 某门课 -> Tasks & Units -> View All Tasks。可以把找到的 class path 传给 managebac_get_class_deadlines 或 managebac_get_class_gpa 的 path 参数。
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/chiang881/managebac-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server