ClaudeがWindowsのUNCパスバグを自らデバッグし、自社のMCPファイルシステムサーバーを修正

✍️ OpenClawRadar📅 公開日: March 18, 2026🔗 Source
ClaudeがWindowsのUNCパスバグを自らデバッグし、自社のMCPファイルシステムサーバーを修正
Ad

開発者が、Windows上のMCP Filesystem Server(デスクトップ拡張機能バージョン)のバグをデバッグして修正するためにClaude Opusを使用した経緯を記録しました。この問題はUNCネットワーク共有パス(例:\\server\share\)に影響を与えていました。

問題点

許可されたディレクトリとしてUNC共有を使用する場合、共有ルートでのlist_directoryは機能しましたが、サブディレクトリやファイルに対する操作は「アクセス拒否 - 許可されたディレクトリ外のパス」というエラーで失敗しました。また、共有ルートへのファイル書き込みも、Windowsエクスプローラーやマップ済みドライブからは完全にアクセス可能であるにもかかわらず失敗しました。

デバッグプロセス

Claudeは以下の点を特定するのに役立ちました:

  • デスクトップ拡張機能バージョンの設定はclaude_desktop_config.jsonではなく、%APPDATA%\Claude\Claude Extensions Settings\ant.dir.ant.anthropic.filesystem.jsonに保存されています。
  • マップ済みドライブ文字に切り替えても機能しませんでした。これはNode.jsのfs.realpath()がサーバー起動時にマップ済みドライブをUNCパスに解決してしまうためです。
  • 根本原因を見つけるために、サーバーのソースファイル(index.jslib.jspath-validation.js)が調査されました。

根本原因

path-validation.js内の関数isPathWithinAllowedDirectories()は、以下のコードでサブディレクトリの所属をチェックしていました:

return normalizedPath.startsWith(normalizedDir + path.sep);

UNC共有ルートはファイルシステムのルート(C:\のような)であり、正規化後も末尾のバックスラッシュを保持します:\\server\share\。これにより二重の末尾バックスラッシュ(\\server\share\\)が生成され、実際のパスと一致しなくなります。コードにはC:\のようなドライブルートの特別な処理がありましたが、UNCルートの処理はありませんでした。

Ad

修正方法

問題のある行を以下に置き換えます:

const dirWithSep = normalizedDir.endsWith(path.sep) ? normalizedDir : normalizedDir + path.sep;
return normalizedPath.startsWith(dirWithSep);

このPowerShellワンライナーでパッチを適用します:

$file = "$env:APPDATA\Claude\Claude Extensions\ant.dir.ant.anthropic.filesystem\node_modules\@modelcontextprotocol\server-filesystem\dist\path-validation.js"
Copy-Item $file "$HOME\Desktop\path-validation.js.backup"
$content = Get-Content $file -Raw
$content = $content.Replace(
  'return normalizedPath.startsWith(normalizedDir + path.sep);',
  'const dirWithSep = normalizedDir.endsWith(path.sep) ? normalizedDir : normalizedDir + path.sep; return normalizedPath.startsWith(dirWithSep);'
)
[System.IO.File]::WriteAllText($file, $content)

その後、Claude Desktopを完全に終了して再起動します。Claudeは再起動後にMCPツールを使用して修正を自身でテストし、サブディレクトリの一覧表示とテストファイルの書き込みで機能を確認しました。

注意:このパッチは拡張機能が自動更新されると上書きされます。修正は@modelcontextprotocol/server-filesystemで上流に実装されるべきです。関連するGitHubイシュー:#1838、#470。

📖 Read the full source: r/ClaudeAI

Ad

👀 See Also

mentioned.to 対 広範な監視ツール:Redditに特化したワークフローの比較
Tools

mentioned.to 対 広範な監視ツール:Redditに特化したワークフローの比較

mentioned.toは、Redditワークフローに特化した監視ツールであり、関連する投稿の追跡、返信機会の特定、成功したコンテンツの分析、返信の下書き作成に焦点を当てており、複数のチャネルにわたる広範なブランド監視ではありません。

OpenClawRadar
ヘドル:Claude Desktop MCP接続のための信頼性強制と監査ログ記録
Tools

ヘドル:Claude Desktop MCP接続のための信頼性強制と監査ログ記録

Heddleは、Claude DesktopのMCP接続に信頼階層、アクセス制御、監査ログを追加するオープンソースツールで、6つのスターターパックを含む単一インターフェースを通じて複数サービスの安全な管理を可能にします。

OpenClawRadar
無料のmacOSメニューバーアプリがClaudeの使用状況をリアルタイムで監視
Tools

無料のmacOSメニューバーアプリがClaudeの使用状況をリアルタイムで監視

開発者が、Claude CodeとOpusを完全に使用して、Claudeの使用状況を監視する無料のmacOSメニューバーアプリを作成しました。このアプリは、5時間と7日間のセッション使用状況バー、コンテキストウィンドウの埋まり率を表示し、制限に近づくと通知を送信します。

OpenClawRadar
GPT-5.1とClaude 4.6を活用したマルチエージェント取引協議会システム
Tools

GPT-5.1とClaude 4.6を活用したマルチエージェント取引協議会システム

開発者は、ZagiHQをオーケストレーションに使用し、3つの並列データ収集エージェントと3つのLLM(GPT-5.1、Claude 4.6 Opus、Claude 4.6 Sonnet)を組み合わせたマルチエージェント取引システムを構築しました。これらのLLMは取引について合意する必要があり、システムは意見の不一致を通じて取引設定をフィルタリングし、手動承認を必須としています。

OpenClawRadar