跳轉到主要內容
Bash 沙箱讓 Claude 執行大多數 shell 命令,而無需停下來請求權限。與其批准每個命令,您可以定義命令可以接觸哪些檔案和網路域,作業系統會為每個 Bash 命令及其子流程強制執行該邊界。 本頁涵蓋如何:
若要比較其他隔離方法,例如開發容器、自訂容器和虛擬機,請參閱 Sandbox environments。若要減少 Bash 以外工具的權限提示,請參閱 permission modes

開始使用

沙箱內建於 Claude Code 中,在 macOS、Linux 和 WSL2 上執行。不支援原生 Windows。在 Windows 上,在 WSL2 發行版內執行 Claude Code。 在 macOS 上,無需安裝任何內容:沙箱化使用內建的 Seatbelt 框架。在 Linux 和 WSL2 上,沙箱依賴於兩個套件,詳見 Set up Linux and WSL2。即使您還沒有安裝它們,您也可以從 /sandbox 開始,因為其面板會顯示是否缺少任何內容。
1

執行 /sandbox

啟動 Claude Code 工作階段並執行 /sandbox 命令:
/sandbox
這會開啟沙箱面板,有三個標籤:
  • Mode:選擇沙箱化命令的批准方式,詳見下一步
  • Overrides:選擇在沙箱下失敗的命令是否可以回退到執行未沙箱化。這是 allowUnsandboxedCommands 設定
  • Config:檢視已解析的沙箱設定
如果面板只顯示 Dependencies 標籤,則缺少必需的套件。按照 Set up Linux and WSL2 中的說明安裝它,重新啟動 Claude Code,然後再次執行 /sandbox
2

選擇一個模式

在 Mode 標籤上,選擇自動允許或常規權限。自動允許在不提示的情況下執行沙箱化命令,常規權限即使命令沙箱化也保持常規權限提示。請參閱 Sandbox modes 了解在自動允許模式中仍然提示的命令。
3

執行 Bash 命令

要求 Claude 執行命令,例如構建或測試套件。預設情況下,沙箱內的命令只能寫入工作目錄。命令首次需要新的網路域時,Claude Code 會提示批准。無法沙箱化執行的命令會回退到常規權限流程。若要擴大或縮小這些邊界,請參閱 Configure sandboxing
在面板中選擇模式會寫入您專案的本地設定,位於 .claude/settings.local.json,這適用於目前專案,不會簽入 git。若要在所有專案中啟用沙箱,請在 ~/.claude/settings.json 的使用者設定中將 sandbox.enabled 設定為 true。若要為組織中的每個開發人員強制執行沙箱化,請使用 managed settings
預設情況下,如果沙箱因缺少依賴項或不支援的平台而無法啟動,Claude Code 會顯示警告並在沒有沙箱化的情況下執行命令。若要改為將其設為硬失敗,請將 sandbox.failIfUnavailable 設定為 true。這適用於需要沙箱化作為安全閘道的受管部署。

設定 Linux 和 WSL2

在 Linux 和 WSL2 上,沙箱依賴於兩個套件:
  • bubblewrap:無特權沙箱化工具,強制執行檔案系統隔離
  • socat:用於通過沙箱代理路由網路流量的中繼
使用您發行版的套件管理器安裝它們:
sudo apt-get install bubblewrap socat
安裝後,/sandbox 中的 Dependencies 標籤會顯示 ripgrepbubblewrapsocat 和 seccomp 過濾器是否在您的平台上可用。Ripgrep 與原生 Claude Code 二進位檔案一起打包。seccomp 過濾器是可選的,增加 Unix 域套接字阻止。如果缺少,請使用 npm install -g @anthropic-ai/sandbox-runtime 安裝它。 當缺少必需的依賴項時,Dependencies 標籤是唯一顯示的標籤,直到您安裝它。依賴項檢查在啟動時執行,因此在安裝套件後重新啟動 Claude Code,以便 /sandbox 檢測到它們。
在 Ubuntu 24.04 及更新版本上,預設 AppArmor 策略防止 bubblewrap 建立隔離所需的使用者命名空間。若要檢查您的環境(包括 WSL2 內)是否強制執行此限制,請執行 sysctl kernel.apparmor_restrict_unprivileged_userns。如果金鑰不存在或傳回 0,請跳過此步驟。如果傳回 1,請新增授予 bwrap 此功能的 AppArmor 設定檔:
sudo tee /etc/apparmor.d/bwrap > /dev/null <<'EOF'
abi <abi/4.0>,
include <tunables/global>

profile bwrap /usr/bin/bwrap flags=(unconfined) {
  userns,
  include if exists <local/bwrap>
}
EOF
該設定檔僅適用於 bwrap 本身,不適用於在沙箱內執行的命令。重新載入 AppArmor 以應用它:
sudo systemctl reload apparmor
使用 PowerShell 中的 wsl -l -v 檢查您的 WSL 版本。如果您看到 Sandboxing requires WSL2,您的發行版執行的是 WSL1。將其升級到 WSL2 或在沒有沙箱化的情況下執行 Claude Code。在 WSL2 上,沙箱化命令無法啟動 Windows 二進位檔案,例如 cmd.exepowershell.exe/mnt/c/ 下的任何內容。WSL 通過 Unix 套接字將這些交給 Windows 主機,沙箱會阻止此操作。如果命令需要呼叫 Windows 二進位檔案,請將其新增到 excludedCommands,以便它在沙箱外執行。

沙箱模式

Claude Code 提供兩種沙箱模式: 自動允許模式:Bash 命令將嘗試在沙箱內執行,並自動允許而無需權限。無法沙箱化的命令(例如需要存取非允許主機的網路存取的命令)會回退到常規權限流程,其中 Claude Code 檢查您的 permission rules 並提示您進行這些規則不允許的任何命令。 即使在自動允許模式中,以下仍然適用:
  • 明確的 deny rules 始終被尊重
  • 針對 /、您的主目錄或其他關鍵系統路徑的 rmrmdir 命令仍然會觸發權限提示
  • Ask rules 適用於回退到常規權限流程的命令
常規權限模式:所有 Bash 命令都通過常規權限流程進行,即使沙箱化也是如此。這提供了更多控制,但需要更多批准。 在兩種模式中,沙箱強制執行相同的檔案系統和網路限制。區別僅在於沙箱化命令是自動批准還是需要明確權限。 某些命令根本無法在沙箱內執行,例如與其不相容的工具或需要您未允許的主機的工具。與其讓任務失敗或要求您關閉沙箱化,Claude Code 包含一個逃生艙:當命令因沙箱限制而失敗時,Claude 分析失敗,可能使用 dangerouslyDisableSandbox 參數重試命令。重試的命令在沙箱外執行,因此它通過常規權限流程進行,需要您的批准。 您可以通過在 sandbox settings 中設定 "allowUnsandboxedCommands": false 來禁用此逃生艙。禁用時,/sandbox Overrides 標籤顯示為 Strict sandbox modedangerouslyDisableSandbox 參數被完全忽略,所有命令必須沙箱化執行或在 excludedCommands 中明確列出。
自動允許模式獨立於您的權限模式設定工作。即使您不在「接受編輯」模式中,當啟用自動允許時,沙箱化 Bash 命令也會自動執行。這意味著在沙箱邊界內修改檔案的 Bash 命令將執行而不提示,即使檔案編輯工具通常需要批准。

設定沙箱化

通過您的 settings.json 檔案自訂沙箱行為。請參閱 Settings 以了解完整的配置參考。 預設情況下,沙箱化命令只能寫入目前工作目錄。如果子流程命令(如 kubectlterraformnpm)需要寫入專案目錄外,請使用 sandbox.filesystem.allowWrite 授予對特定路徑的存取:
{
  "sandbox": {
    "enabled": true,
    "filesystem": {
      "allowWrite": ["~/.kube", "/tmp/build"]
    }
  }
}
這些路徑在作業系統級別強制執行,因此在沙箱內執行的所有命令(包括其子流程)都尊重它們。當工具需要對特定位置的寫入存取時,這是推薦的方法,而不是使用 excludedCommands 將工具排除在沙箱外。 當在多個 settings scopes 中定義相同的檔案系統陣列時,陣列被合併:來自每個範圍的路徑被組合,而不是被替換。 路徑前綴控制路徑的解析方式:
前綴含義範例
/從檔案系統根目錄的絕對路徑/tmp/build 保持 /tmp/build
~/相對於主目錄~/.kube 變成 $HOME/.kube
./ 或無前綴相對於專案設定的專案根目錄,或相對於 ~/.claude 的使用者設定.claude/settings.json 中的 ./output 解析為 <project-root>/output
此語法與 Read and Edit permission rules 不同,後者使用 //path 表示絕對路徑,/path 表示專案相對路徑。沙箱檔案系統路徑使用標準慣例:/tmp/build 是絕對路徑。 您也可以使用 sandbox.filesystem.denyWritesandbox.filesystem.denyRead 拒絕寫入或讀取存取,並使用 sandbox.filesystem.allowRead 重新允許讀取 denyRead 區域內的特定路徑。 下面的範例阻止從整個主目錄讀取,同時仍允許從目前專案讀取。將其放在您的專案的 .claude/settings.json 中,因為相對路徑 . 僅在配置位於專案設定中時才解析為專案根目錄:
{
  "sandbox": {
    "enabled": true,
    "filesystem": {
      "denyRead": ["~/"],
      "allowRead": ["."]
    }
  }
}
allowRead 中的 . 解析為專案根目錄,因為此配置位於專案設定中。如果您將相同的配置放在 ~/.claude/settings.json 中,. 將解析為 ~/.claude,專案檔案將保持被 denyRead 規則阻止。

沙箱化如何運作

檔案系統隔離

沙箱化 Bash 工具將檔案系統存取限制在特定目錄:
  • 預設寫入行為:對目前工作目錄及其子目錄的讀取和寫入存取
  • 預設讀取行為:對整個電腦的讀取存取,除了某些被拒絕的目錄。請注意,此預設仍允許讀取認證檔案,例如 ~/.aws/credentials~/.ssh/。將它們新增到 denyRead 以阻止它們。
  • 被阻止的存取:無法在沒有明確權限的情況下修改目前工作目錄外的檔案,包括 shell 配置檔案(例如 ~/.bashrc)和 /bin/ 中的系統二進位檔案
  • Git worktrees:當工作目錄是連結的 git worktree 時,沙箱也允許寫入主儲存庫的共享 .git 目錄,以便 git commit 等命令可以更新 refs 和索引。對該目錄內的 hooks/config 的寫入仍然被拒絕。
  • 可配置:通過設定定義自訂允許和拒絕的路徑
您可以使用設定中的 sandbox.filesystem.allowWrite 授予對其他路徑的寫入存取。這些限制在作業系統級別強制執行,因此它們適用於所有子流程命令,包括 kubectlterraformnpm 等工具,而不僅僅是 Claude 的檔案工具。

網路隔離

網路存取通過在沙箱外執行的代理伺服器進行控制:
  • 域名限制:沒有預先允許的域名。命令首次需要新的域名時,Claude Code 會提示批准。使用 allowedDomains 預先允許域名以避免提示。
  • 受管鎖定:如果在受管設定中設定了 allowManagedDomainsOnly,非允許的域名會自動被阻止而不是提示,只有來自受管設定的 allowedDomains 被尊重。
  • 自訂代理支援:進階使用者可以在出站流量上實施自訂規則
  • 全面覆蓋:限制適用於所有指令碼、程式和由命令產生的子流程
內建代理根據請求的主機名強制執行允許清單,不終止或檢查 TLS 流量。請參閱 Security limitations 了解此設計的含義,以及 Custom proxy configuration 如果您的威脅模型需要 TLS 檢查。

作業系統級別的強制執行

沙箱化 Bash 工具利用作業系統安全原語:
  • macOS:使用 Seatbelt 進行沙箱強制執行
  • Linux:使用 bubblewrap 進行隔離
  • WSL2:使用 bubblewrap,與 Linux 相同
不支援 WSL1,因為 bubblewrap 需要僅在 WSL2 中可用的核心功能。這些作業系統級別的限制確保由 Claude Code 命令產生的所有子流程都繼承相同的安全邊界。 這些相同的原語可作為獨立的 @anthropic-ai/sandbox-runtime 套件使用,Sandbox environments 頁面涵蓋作為包裝整個 Claude Code 流程的單獨方法。

沙箱化與權限和權限模式的關係

沙箱化、permission rulespermission modes 是互補的層。下面的部分涵蓋沙箱如何與每個互動。

權限規則

權限規則和沙箱化控制不同的事物:
  • 權限規則控制 Claude Code 可以使用哪些工具,並在任何工具執行之前進行評估。它們適用於所有工具:Bash、Read、Edit、WebFetch、MCP 和其他工具。
  • 沙箱化提供作業系統級別的強制執行,限制 Bash 命令在檔案系統和網路級別可以存取的內容。它僅適用於 Bash 命令及其子流程。
這兩層在強制執行方式上也有所不同。Claude Code 在命令執行之前根據命令字串評估權限決定,在自動模式中,還根據單獨分類器對命令是否安全的判斷。作業系統在執行流程上強制執行沙箱邊界,因此無論模型選擇執行什麼,它都成立,即使允許的命令執行的操作超出其名稱所示。 檔案系統和網路限制通過沙箱設定和權限規則進行配置:
設定或規則它的作用
sandbox.filesystem.allowWrite授予子流程對工作目錄外路徑的寫入存取
sandbox.filesystem.denyWritesandbox.filesystem.denyRead阻止子流程對特定路徑的存取
sandbox.filesystem.allowRead重新允許讀取 denyRead 區域內的特定路徑
Edit 允許規則授予對特定路徑的寫入存取,與 sandbox.filesystem.allowWrite 相同
ReadEdit 拒絕規則阻止對特定檔案或目錄的存取
WebFetch 允許和拒絕規則控制域名存取
沙箱 allowedDomains控制 Bash 命令可以到達的域名
沙箱 deniedDomains阻止特定域名,即使更廣泛的 allowedDomains 萬用字元會允許它們
來自 sandbox.filesystem 設定和權限規則的路徑被合併到最終沙箱配置中。 claude-code repository 的 examples 目錄包含常見部署場景的入門設定配置,包括沙箱特定的範例。使用這些作為起點,並根據您的需求進行調整。

權限模式

/sandbox 不是 permission mode。權限模式決定工具呼叫是否執行以及您是否首先被提示,而沙箱限制 Bash 命令執行後可以存取的內容。它們在控制的內容和替換每個操作提示的內容上有所不同:
它控制什麼替換提示的內容
/sandboxBash 命令執行後可以存取的內容沙箱邊界本身,在 auto-allow mode
Auto mode每個工具呼叫是否執行檢查操作的分類器
--dangerously-skip-permissions每個工具呼叫是否執行無。Protected path 檢查也被跳過;只有移除 / 或您的主目錄仍然提示
沙箱的 auto-allow modeauto mode 分開:自動允許批准 Bash 命令,因為沙箱邊界包含它們,而自動模式使用分類器檢查操作。這兩個獨立工作,可以結合。若要為無人值守執行選擇隔離邊界,請參閱 Sandbox environments

為您的組織設定沙箱

管理員可以為每個使用者要求沙箱化,防止開發人員擴大策略,並通過公司代理路由沙箱流量。

使用受管設定強制執行沙箱化

若要為每個開發人員要求沙箱,通過 managed settings 傳遞 sandbox 金鑰,可以是由您的 MDM 管理的檔案,也可以是通過 Claude.ai 上的 server-managed settings 以下受管設定配置啟用沙箱,如果沙箱無法初始化則拒絕啟動 Claude Code,並防止模型在沙箱外重試命令:
{
  "sandbox": {
    "enabled": true,
    "failIfUnavailable": true,
    "allowUnsandboxedCommands": false
  }
}
超過 enabled 的兩個金鑰控制沙箱無法執行命令時會發生什麼:
  • failIfUnavailable:缺少的依賴項(例如 Linux 上的 bubblewrap)會阻止 Claude Code 啟動,而不是顯示警告並回退到未沙箱化執行
  • allowUnsandboxedCommands: falsedangerouslyDisableSandbox 逃生艙被忽略,因此在沙箱下失敗的命令無法在其外重試
值得考慮與它們一起的兩個補充。為任何必須在沒有隔離的情況下執行的組織批准的工具新增 excludedCommands。為認證目錄(例如 ~/.aws~/.ssh)新增 denyRead 項目,預設讀取策略仍允許這些。 沙箱不在原生 Windows 上執行,因此如果您的機隊包括 Windows 主機,請將此配置限制在 macOS 和 Linux,或讓這些使用者在 WSL2 或容器內執行 Claude Code。

防止開發人員擴大策略

對於布林金鑰(例如 enabledfailIfUnavailable),Claude Code 使用受管值並忽略開發人員在本地設定的任何內容。對於陣列金鑰(例如 excludedCommandsallowRead),Claude Code 合併來自每個範圍的項目,因此開發人員可以附加擴大策略的項目。 在受管設定中將 allowManagedReadPathsOnly 設定為 true,以便只有來自受管設定的 allowRead 項目被尊重。使用者、專案和本地 allowRead 項目被忽略。這防止開發人員擴大讀取存取超過組織批准的路徑。若要以相同方式將網路域鎖定到受管值,請設定 allowManagedDomainsOnly excludedCommands 沒有等效的受管專用鎖定,因此開發人員總是可以附加在沙箱外執行其他命令的項目。保持受管清單狹窄。

自訂代理配置

對於需要進階網路安全的組織,您可以實施自訂代理以:
  • 解密和檢查 HTTPS 流量
  • 應用自訂過濾規則
  • 記錄所有網路請求
  • 與現有安全基礎設施整合
若要將 Claude Code 指向您的代理,請在 sandbox settings 中設定代理連接埠:
{
  "sandbox": {
    "network": {
      "httpProxyPort": 8080,
      "socksProxyPort": 8081
    }
  }
}

故障排除

某些命令在沙箱內失敗,即使它們在沙箱外工作。下面的修復涵蓋最常見的情況。
  • 命令因主機不允許錯誤而失敗:許多 CLI 工具需要到達特定主機。在提示時授予權限會將主機新增到您的允許清單,以便工具在將來在沙箱內執行。
  • jest 掛起或失敗watchman 與沙箱不相容。改為執行 jest --no-watchman
  • Go 型 CLI 在 macOS 上 TLS 驗證失敗ghgcloudterraform 等工具在 Seatbelt 下可能無法進行 TLS 驗證。在 excludedCommands 中列出這些工具以在沙箱外執行它們。如果您使用 httpProxyPort 與 MITM 代理和自訂 CA,請改為將 enableWeakerNetworkIsolation 設定為 true
  • docker 命令失敗docker 與沙箱不相容。將 docker * 新增到 excludedCommands 以在沙箱外執行它。
  • Bubblewrap 在容器內啟動失敗:在無特權容器中,bubblewrap 無法掛載新的 /proc 檔案系統。將 enableWeakerNestedSandbox 設定為 true,以便內部沙箱綁定掛載容器的現有 /proc。僅在外部容器已提供您需要的隔離邊界時使用此設定,因為它向沙箱化命令公開流程資訊,新的 /proc 掛載會隱藏。
  • Linux 上的 Seccomp 過濾器:seccomp 過濾器是阻止 Unix 域套接字所必需的。/sandbox 中的 Dependencies 標籤顯示它是否可用。如果缺少,請執行 npm install -g @anthropic-ai/sandbox-runtime 安裝幫助程式。
  • --dangerously-skip-permissions 以 root 身份失敗:在 Linux 和 macOS 上以 root 身份或通過 sudo 執行時,此旗標被阻止,因為 root 存取加上沒有權限提示可以修改系統上的任何檔案或服務。檢查在識別的沙箱內自動跳過。若要在容器中自主執行,請使用 dev container 配置,它以非 root 使用者身份執行 Claude Code。

限制

沙箱化減少風險,但不是完整的隔離邊界。在依賴它作為硬安全控制之前,請檢查下面的限制。

安全限制

  • 網路過濾:網路過濾系統通過限制流程允許連接的域名來運作。內建代理不終止或對出站流量執行 TLS 檢查,因此加密連接的內容不被檢查。您負責確保只有受信任的域名在您的策略中被允許。
允許廣泛域名(例如 github.com)可能會為資料洩露建立路徑。因為代理根據用戶端提供的主機名進行允許決定而不檢查 TLS,在沙箱內執行的程式碼可能可以使用 domain fronting 或類似技術到達允許清單外的主機。如果您的威脅模型需要更強的保證,請配置 custom proxy,它終止 TLS 並檢查流量,並在沙箱內安裝其 CA 憑證。更強的 TLS 感知網路隔離是一個活躍的開發領域。
  • 通過 Unix 套接字的特權提升allowUnixSockets 配置可能會無意中授予對強大系統服務的存取,這可能導致沙箱繞過。例如,允許存取 /var/run/docker.sock 有效地通過 Docker 套接字授予對主機系統的存取。仔細考慮您通過沙箱允許的任何 Unix 套接字。
  • 檔案系統權限提升:過於寬泛的檔案系統寫入權限可能導致特權提升攻擊。允許寫入包含 $PATH 中可執行檔案的目錄、系統配置目錄或使用者 shell 配置檔案(例如 .bashrc.zshrc)可能導致當其他使用者或系統流程存取這些檔案時在不同安全上下文中執行程式碼。
  • Linux 沙箱強度:Linux 實現提供強大的檔案系統和網路隔離,但包含一個 enableWeakerNestedSandbox 模式,使其能夠在 Docker 環境中工作而無需特權命名空間,或在 Linux 主機上禁用無特權使用者命名空間的情況下。此選項大大削弱了安全性,應僅在其他隔離被強制執行時使用。
  • 設定檔案受保護:沙箱自動拒絕對 Claude Code 的 settings.json 檔案在每個範圍和受管設定目錄的寫入存取,因此沙箱化命令無法修改其自己的策略。

平台和工具相容性

  • 平台支援:支援 macOS、Linux 和 WSL2。不支援 WSL1 和原生 Windows。
  • 效能開銷:最小,但某些檔案系統操作可能稍慢。
  • 工具相容性:某些需要特定系統存取模式的工具可能需要配置調整,或可能需要在沙箱外執行。

範圍

沙箱隔離 Bash 子流程。其他工具在不同的邊界下運作:
  • 內建檔案工具:Read、Edit 和 Write 直接使用權限系統,而不是通過沙箱執行。請參閱 permissions
  • 電腦使用:當 Claude 打開應用程式並控制您的螢幕時,它在您的實際桌面上執行,而不是在隔離環境中。每個應用程式的權限提示控制每個應用程式。請參閱 CLI 中的電腦使用Desktop 中的電腦使用
  • 環境變數:沙箱化 Bash 命令預設繼承父流程環境,包括在那裡設定的任何認證。若要從子流程中去除 Anthropic 和雲端提供商認證,請設定 CLAUDE_CODE_SUBPROCESS_ENV_SCRUB
  • 子代理subagents 在與父工作階段相同的流程中執行,並使用相同的沙箱配置。當在父工作階段中啟用沙箱化時,子代理內的 Bash 命令被沙箱化。
有效的沙箱化需要同時進行檔案系統和網路隔離。沒有網路隔離,受損的代理可能會洩露敏感檔案,如 SSH 金鑰。沒有檔案系統隔離,受損的代理可能會後門系統資源以獲得網路存取。當您擴大預設值時,檢查 allowWrite 路徑、廣泛的 allowedDomains 項目或 excludedCommands 例外是否不會撤銷另一側的限制。

另請參閱