io.github.drfccv/mcp-server-12306
平台与服务by drfccv
一个提供 12306 车票查询能力的 MCP server,可用于检索车次、余票等相关信息。
将12306车次和余票查询封装成MCP服务,省去手动查票的麻烦,也让AI助手接入铁路数据更直接。
什么是 io.github.drfccv/mcp-server-12306?
一个提供 12306 车票查询能力的 MCP server,可用于检索车次、余票等相关信息。
README
🚄 MCP Server 12306
✨ 项目简介
MCP Server 12306 是一款基于 Model Context Protocol (MCP) 的高性能火车票查询服务,支持官方 12306 余票、票价、车站、经停、换乘查询以及智能时间工具,适配 AI/自动化/智能助手等场景,开箱即用。
🚀 功能亮点
- 实时余票/车次/座席/时刻/换乘一站式查询
- 全国车站信息管理与模糊搜索,支持中文、拼音、简拼、三字码
- 官方经停站、中转换乘方案全支持
- 实时查询各车次票价信息
- 智能时间工具,支持时区和时间戳
- 双传输模式:Stdio(Claude Desktop 推荐)| Streamable HTTP(远程部署)
- MCP 2025-03-26 标准,AI/自动化场景即插即用
🛠️ 快速上手
本项目支持两种运行模式:
- Stdio 模式:适用于 Claude Desktop 等本地 MCP 客户端(推荐)。
- Streamable HTTP 模式:适用于远程部署或通过 SSE/POST 访问。
模式 1:Stdio 模式(Claude Desktop 推荐)
在此模式下,MCP Server 通过标准输入/输出与客户端通信,无需占用网络端口。
方式 A:使用 uvx(推荐)
uvx 是 uv 包管理器提供的工具,环境隔离且启动极快。
{
"mcpServers": {
"12306": {
"command": "uvx",
"args": ["mcp-server-12306"]
}
}
}
方式 B:使用 pipx
如果您更习惯使用 pipx:
{
"mcpServers": {
"12306": {
"command": "pipx",
"args": ["run", "--no-cache", "mcp-server-12306"]
}
}
}
方式 C:本地源码运行
适用于开发者调试:
cd mcp-server-12306
uv sync
{
"mcpServers": {
"12306": {
"command": "uv",
"args": ["--directory", "/path/to/mcp-server-12306", "run", "mcp-server-12306"]
}
}
}
模式 2:Streamable HTTP 模式
在此模式下,Server 启动一个 Web 服务(默认 8000 端口),支持 MCP 的 SSE 和 POST 交互。
方式 A:pip 安装后运行
# 安装 HTTP 模式(含 FastAPI / uvicorn)
pip install mcp-server-12306[http]
# 启动
mcp-12306
方式 B:本地源码运行
# 1. 克隆并安装依赖
git clone https://github.com/drfccv/mcp-server-12306.git
cd mcp-server-12306
uv sync --extra http
# 2. 启动服务器
uv run python scripts/start_server.py
MCP 客户端配置:
{
"mcpServers": {
"12306": {
"url": "http://localhost:8000/mcp"
}
}
}
方式 C:Docker 部署
# 拉取镜像并运行
docker run -d -p 8000:8000 --name mcp-server-12306 drfccv/mcp-server-12306:latest
🤖 工具一览
支持的主流程工具
| 工具名 | 功能描述 |
|---|---|
query-tickets | 余票/车次/座席/时刻一站式查询 |
query-ticket-price | 实时查询各车次票价信息 |
search-stations | 车站模糊搜索,支持中文/拼音/简拼 |
query-transfer | 中转换乘方案,自动拼接最优路径 |
get-train-route-stations | 查询指定列车经停站及时刻表 |
get-train-no-by-train-code | 车次号转官方唯一编号 |
get-current-time | 当前时间与相对日期,辅助日期选择 |
📚 工具文档
本项目所有主流程工具的详细功能、实现与使用方法,均已收录于 /docs 目录下:
- query_tickets.md — 余票/车次/座席/时刻一站式查询
- query_ticket_price.md — 实时查询各车次票价信息
- search_stations.md — 车站智能搜索
- query_transfer.md — 中转换乘方案
- get_train_route_stations.md — 查询列车经停站
- get_current_time.md — 获取当前时间与相对日期
每个文档包含:
- 工具功能说明
- 实现方法
- 请求参数与返回示例
- 典型调用方式
如需二次开发或集成,建议先阅读对应工具的文档。
🧩 目录结构
src/mcp_12306/ # 主源代码
├─ http_server.py # FastAPI HTTP 传输层
├─ stdio_server.py # Stdio 传输层 + CLI 入口
├─ services/ # 业务逻辑
│ ├─ station_service.py # 车站数据服务
│ └─ ticket_service.py # 票务查询核心(stdio/HTTP 共享)
├─ utils/ # 配置与日期工具
│ ├─ config.py
│ └─ date_utils.py
└─ resources/ # 静态资源(车站数据)
scripts/ # 启动与数据更新脚本
├─ start_server.py # HTTP 模式一键启动
└─ update_stations.py # 更新车站数据
📄 License
MIT License
⚠️ 免责声明
- 本项目仅供学习、研究与技术交流,严禁用于任何商业用途。
- 本项目不存储、不篡改、不传播任何 12306 官方数据,仅作为官方公开接口的智能聚合与转发。
- 使用本项目造成的任何后果(包括但不限于账号封禁、数据异常、法律风险等)均由使用者本人承担,项目作者不承担任何责任。
- 请遵守中国法律法规及 12306 官方相关规定,合理合规使用。
常见问题
io.github.drfccv/mcp-server-12306 是什么?
一个提供 12306 车票查询能力的 MCP server,可用于检索车次、余票等相关信息。
相关 Skills
Slack动图
by anthropics
面向Slack的动图制作Skill,内置emoji/消息GIF的尺寸、帧率和色彩约束、校验与优化流程,适合把创意或上传图片快速做成可直接发送的Slack动画。
✎ 帮你快速做出适配 Slack 的动图,内置约束规则和校验工具,少踩上传与播放坑,做表情包和演示都更省心。
MCP构建
by anthropics
聚焦高质量 MCP Server 开发,覆盖协议研究、工具设计、错误处理与传输选型,适合用 FastMCP 或 MCP SDK 对接外部 API、封装服务能力。
✎ 想让 LLM 稳定调用外部 API,就用 MCP构建:从 Python 到 Node 都有成熟指引,帮你更快做出高质量 MCP 服务器。
接口测试套件
by alirezarezvani
扫描 Next.js、Express、FastAPI、Django REST 的 API 路由,自动生成覆盖鉴权、参数校验、错误码、分页、上传与限流场景的 Vitest 或 Pytest 测试套件。
✎ 帮你把API与集成测试自动化跑顺,减少回归漏测;能力全面,尤其适合复杂接口场景的QA团队。
相关 MCP Server
Slack 消息
编辑精选by Anthropic
Slack 是让 AI 助手直接读写你的 Slack 频道和消息的 MCP 服务器。
✎ 这个服务器解决了团队协作中需要 AI 实时获取 Slack 信息的痛点,特别适合开发团队让 Claude 帮忙汇总频道讨论或发送通知。不过,它目前只是参考实现,文档有限,不建议在生产环境直接使用——更适合开发者学习 MCP 如何集成第三方服务。
by netdata
io.github.netdata/mcp-server 是让 AI 助手实时监控服务器指标和日志的 MCP 服务器。
✎ 这个工具解决了运维人员需要手动检查系统状态的痛点,最适合 DevOps 团队让 Claude 自动分析性能数据。不过,它依赖 NetData 的现有部署,如果你没用过这个监控平台,得先花时间配置。
by d4vinci
Scrapling MCP Server 是专为现代网页设计的智能爬虫工具,支持绕过 Cloudflare 等反爬机制。
✎ 这个工具解决了爬取动态网页和反爬网站时的头疼问题,特别适合需要批量采集电商价格或新闻数据的开发者。不过,它依赖外部浏览器引擎,资源消耗较大,不适合轻量级任务。