e-Gov Law MCP Server
Enables intelligent search and retrieval of Japanese legal statutes through the e-Gov API. Supports smart lookup of laws and articles with abbreviation recognition, batch processing, and multi-tier caching for high-performance legal research.
README
e-Gov Law MCP Server v2 🏛️⚖️
Ultra Smart & Efficient - 日本政府e-Gov法令APIのための高性能Model Context Protocol (MCP) サーバー
🚀 v2の特徴: FastMCP準拠、Windows完全対応、58%コード削減、3層キャッシュ最適化、エンタープライズセキュリティ
✨ 主な特徴
🎯 インテリジェント法律検索
- 16基本法直接マッピング: 六法 + 現代重要法への瞬時アクセス
- 20略称自動変換: 道交法→道路交通法、労基法→労働基準法
- 複雑パターン対応: 「第325条の3」「第9条第2項第1号」等
- 4段階条文抽出: コンテンツスコアリングによる高精度抽出
⚡ ハイパフォーマンス
- 3層LRUキャッシュ: 法律検索(2h)、法律内容(1h)、条文(30m)
- 並行処理最適化: 50リクエスト/5.27秒の高速レスポンス
- メモリ監視: psutil統合、自動クリーンアップ(512MB制限)
- バッチ処理: 最大200件の一括検索対応
🛡️ エンタープライズセキュリティ
- インジェクション防止: SQL、XSS、JNDI、コード実行を完全ブロック
- 入力検証: 長さ制限、特殊文字フィルタリング
- API保護: レート制限、403 Forbidden応答
- エラーマスキング: 内部情報漏洩防止
🌐 クロスプラットフォーム
- Windows完全対応: psutilオプション、パス互換性
- FastMCP準拠: Context logging、ToolError例外、自動シリアライゼーション
- 柔軟設定: YAML設定ファイル、プロンプト外部化
🛠️ 8つの高機能MCPツール
| ツール | 機能 | 特徴 |
|---|---|---|
find_law_article |
条文検索 | AI駆動パターンマッチング、漢数字対応 |
search_laws |
法律検索 | フィルタリング、ページネーション |
search_laws_by_keyword |
キーワード検索 | フルテキスト検索、ハイライト |
get_law_content |
法律全文取得 | サイズ制限対応(800KB)、XML/JSON |
batch_find_articles |
バッチ検索 | 最大200件、パフォーマンス統計 |
prefetch_common_laws |
キャッシュ最適化 | 頻出法律の事前読み込み |
get_cache_stats |
監視 | リアルタイムパフォーマンス監視 |
clear_cache |
メンテナンス | 粒度別キャッシュ管理 |
📊 対応法令
🚀 高速アクセス対応(直接マッピング済み)
六法
- 憲法(昭和二十一年憲法)
- 民法(明治二十九年法律第八十九号)
- 刑法(明治四十年法律第四十五号)
- 商法(昭和二十三年法律第二十五号)
- 民事訴訟法(平成八年法律第百九号)
- 刑事訴訟法(昭和二十三年法律第百三十一号)
現代重要法
- 会社法、労働基準法、所得税法、法人税法
- 著作権法、特許法、道路交通法、建築基準法
- 独占禁止法、消費者契約法、特定受託事業者取引適正化法
🔍 略称検索対応
道交法 → 道路交通法 労基法 → 労働基準法
独禁法 → 独占禁止法 消契法 → 消費者契約法
著作権 → 著作権法 特許 → 特許法
税法 → 所得税法 労働法 → 労働基準法
📈 実証された性能
🏆 テスト結果(40+テスト、65%カバレッジ)
- ✅ 機能テスト: 全ツール、エッジケース、境界値
- ✅ セキュリティテスト: インジェクション攻撃、不正ペイロード
- ✅ パフォーマンステスト: 並行性50/50成功、5.27秒
- ✅ 統合テスト: FastMCP機能、Windows互換性
📊 パフォーマンス指標
- 並行処理: 50リクエスト同時処理 → 100%成功
- キャッシュヒット率: 主要法律で90%以上
- レスポンス時間: 直接マッピング法律 < 1秒
- メモリ効率: 512MB制限内で安定動作
🚀 クイックスタート
前提条件
uvをインストール:
# macOS/Linux
curl -LsSf https://astral.sh/uv/install.sh | sh
# Windows
powershell -c "irm https://astral.sh/uv/install.ps1 | iex"
インストール
# リポジトリをクローン
git clone https://github.com/ryoooo/e-gov-law-mcp.git
cd e-gov-law-mcp
# 依存関係をインストール
uv sync
# パフォーマンス監視を有効にする場合(オプション)
uv add psutil
Claude Desktop設定
設定ファイルの場所:
- Windows:
%APPDATA%\Claude\claude_desktop_config.json - macOS:
~/Library/Application Support/Claude/claude_desktop_config.json - Linux:
~/.config/claude/claude_desktop_config.json
設定例:
{
"mcpServers": {
"e-gov-law": {
"command": "uv",
"args": [
"run",
"--directory",
"/path/to/e-gov-law-mcp",
"python",
"run_server.py"
]
}
}
}
💡 使用例
Claude Desktopでの基本使用
民法192条について詳しく教えて
憲法第9条第2項の条文と解釈を知りたい
会社法325条の3の株主総会決議について
労基法の有給休暇の規定を調べて
道交法の飲酒運転の罰則は?
プログラム使用例
import asyncio
from fastmcp import Client
async def search_example():
async with Client(["uv", "run", "python", "src/mcp_server.py"]) as client:
# 民法192条を検索
result = await client.call_tool("find_law_article", {
"law_name": "民法",
"article_number": "192"
})
print(result[0].text)
# バッチ検索
batch_data = json.dumps([
{"law": "民法", "article": "192"},
{"law": "憲法", "article": "9"}
])
batch_result = await client.call_tool("batch_find_articles", {
"law_article_pairs": batch_data
})
asyncio.run(search_example())
🔧 開発とテスト
開発環境セットアップ
git clone https://github.com/ryoooo/e-gov-law-mcp.git
cd e-gov-law-mcp
uv sync --dev
テスト実行
# 全テスト実行(40+テスト)
uv run pytest
# カバレッジ付きテスト
uv run pytest --cov=src
# セキュリティテスト
uv run pytest test_comprehensive_ultra.py::TestSecurityAndRobustness -v
# パフォーマンステスト
uv run pytest test_comprehensive_ultra.py::TestPerformanceAndScalability -v
# FastMCP統合テスト
uv run pytest test_fastmcp_integration.py -v
コード品質
# フォーマット
uv run black src/ tests/
# リント
uv run ruff check src/ tests/
# 型チェック
uv run mypy src/
⚙️ 設定
環境変数
# e-Gov API設定
export EGOV_API_URL="https://laws.e-gov.go.jp/api/2"
export EGOV_API_TOKEN="" # 通常は不要
# サーバー設定
export MCP_SERVER_NAME="e-Gov Law Server v2"
export LAW_CONFIG_PATH="config/laws.yaml"
設定ファイル
config/laws.yaml: 法律マッピング、略称定義prompts/legal_analysis.md: 法的分析指導プロンプト
🏗️ アーキテクチャ
e-Gov Law MCP Server v2
├── 🎯 FastMCP Core (Context logging, ToolError, Auto-serialization)
├── 🔍 Smart Law Lookup (16 basic laws + 20 aliases)
├── ⚡ 3-Tier Cache System (LRU + TTL + Memory monitoring)
├── 🛡️ Security Layer (Injection prevention, Input validation)
├── 🌐 Cross-Platform Support (Windows/Linux/macOS)
└── 📊 Performance Monitoring (Real-time stats, Batch optimization)
📝 API詳細
find_law_article
最も重要なツール - 高精度条文検索
await client.call_tool("find_law_article", {
"law_name": "民法", # 法律名(略称可)
"article_number": "325条の3" # 条文番号(複雑パターン対応)
})
対応パターン例:
"192"→ 第192条"第192条"→ 第192条"325条の3"→ 第325条の3"第9条第2項"→ 第9条第2項"第9条第2項第1号"→ 第9条第2項第1号
batch_find_articles
高速バッチ処理 - 最大200件の一括検索
batch_data = json.dumps([
{"law": "民法", "article": "192"},
{"law": "憲法", "article": "9"},
{"law": "会社法", "article": "423"}
])
await client.call_tool("batch_find_articles", {
"law_article_pairs": batch_data
})
🔧 トラブルシューティング
Windows環境トラブルシューティング
問題: "No module named 'yaml'" エラー
# 解決方法1: uv syncで依存関係をインストール
cd C:\path\to\e-gov-law-mcp
uv sync
# 解決方法2: 手動インストール
pip install PyYAML httpx fastmcp
問題: "No module named 'psutil'" 警告
# psutilはオプションのパフォーマンス監視ライブラリ
# インストールしなくても動作します
# パフォーマンス監視を有効にしたい場合
uv add psutil
# または
pip install psutil
問題: FastMCPコマンドエラー
# Claude Desktop設定でrun_server.pyを使用
# 依存関係チェック機能付き
"command": "uv",
"args": [
"run",
"--directory",
"C:\\path\\to\\e-gov-law-mcp",
"python",
"run_server.py"
]
その他のWindows問題
# パス区切り文字 → pathlibで自動解決
# UTF-8エンコーディング → 明示的指定済み
# メモリ監視 → psutilなしでも動作
パフォーマンス最適化
# キャッシュ統計確認
await client.call_tool("get_cache_stats", {})
# 頻出法律をプリフェッチ
await client.call_tool("prefetch_common_laws", {})
# キャッシュクリア(メモリ不足時)
await client.call_tool("clear_cache", {"cache_type": "all"})
📚 参考リンク
🤝 貢献
- リポジトリをフォーク
- 機能ブランチを作成:
git checkout -b feature/amazing-feature - 変更をコミット:
git commit -m 'feat: Add amazing feature' - ブランチにプッシュ:
git push origin feature/amazing-feature - プルリクエストを作成
貢献ガイドライン
- テストカバレッジを維持(65%以上)
- セキュリティテストを必須追加
- FastMCP仕様準拠を確認
- Windows互換性をテスト
📄 ライセンス
MIT License - 詳細は LICENSE ファイルを参照
🙏 謝辞
🚀 Ultra Smart & Efficient e-Gov Law MCP Server v2
日本法令検索の新しいスタンダード
推荐服务器
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 模型以安全和受控的方式获取实时的网络信息。