Skip to content

Latest commit

 

History

History
455 lines (320 loc) · 27.9 KB

File metadata and controls

455 lines (320 loc) · 27.9 KB

MCP 安全性:AI 系統的全面保護

MCP 安全性最佳實踐

(點擊上方圖片觀看本課程影片)

安全性是 AI 系統設計的基礎,因此我們將其作為第二部分的重點。這與微軟 Secure by Design 原則相一致。

模型上下文協議(MCP)為 AI 驅動的應用程式帶來了強大的新功能,但也引入了超越傳統軟體風險的獨特安全挑戰。MCP 系統面臨既有的安全問題(如安全編碼、最小權限、供應鏈安全)以及新的 AI 特定威脅,包括提示注入、工具中毒、會話劫持、混淆代理攻擊、令牌傳遞漏洞和動態能力修改。

本課程將探討 MCP 實作中最關鍵的安全風險,涵蓋身份驗證、授權、過度權限、間接提示注入、會話安全、混淆代理問題、令牌管理和供應鏈漏洞。您將學習可行的控制措施和最佳實踐,以減輕這些風險,同時利用 Microsoft 解決方案(如 Prompt Shields、Azure Content Safety 和 GitHub Advanced Security)來加強您的 MCP 部署。

學習目標

完成本課程後,您將能夠:

  • 識別 MCP 特定威脅:了解 MCP 系統中的獨特安全風險,包括提示注入、工具中毒、過度權限、會話劫持、混淆代理問題、令牌傳遞漏洞和供應鏈風險
  • 應用安全控制措施:實施有效的緩解措施,包括強大的身份驗證、最小權限訪問、安全的令牌管理、會話安全控制和供應鏈驗證
  • 利用 Microsoft 安全解決方案:了解並部署 Microsoft Prompt Shields、Azure Content Safety 和 GitHub Advanced Security 來保護 MCP 工作負載
  • 驗證工具安全性:認識工具元數據驗證、動態變更監控以及防禦間接提示注入攻擊的重要性
  • 整合最佳實踐:結合既有的安全基礎(如安全編碼、伺服器強化、零信任)與 MCP 特定控制措施,實現全面保護

MCP 安全架構與控制措施

現代 MCP 實作需要分層的安全方法,既要應對傳統軟體安全問題,也要解決 AI 特定威脅。快速演進的 MCP 規範不斷完善其安全控制措施,實現與企業安全架構和既有最佳實踐的更好整合。

根據 Microsoft Digital Defense Report 的研究,98% 的已報告漏洞可以通過強健的安全衛生措施來防止。最有效的保護策略是將基礎安全實踐與 MCP 特定控制措施相結合——經證明的基線安全措施在降低整體安全風險方面仍然最具影響力。

當前的安全環境

注意:此資訊反映截至 2025 年 8 月 18 日 的 MCP 安全標準。MCP 協議正在快速演進,未來的實作可能會引入新的身份驗證模式和增強的控制措施。請始終參考最新的 MCP 規範MCP GitHub 儲存庫安全最佳實踐文件 以獲取最新指導。

MCP 身份驗證的演進

MCP 規範在身份驗證和授權方法上已經有了顯著的演進:

  • 最初的方法:早期規範要求開發人員實作自訂身份驗證伺服器,MCP 伺服器作為 OAuth 2.0 授權伺服器直接管理用戶身份驗證
  • 當前標準(2025-06-18):更新的規範允許 MCP 伺服器將身份驗證委派給外部身份提供者(如 Microsoft Entra ID),提高了安全性並降低了實作的複雜性
  • 傳輸層安全性:增強了對本地(STDIO)和遠端(Streamable HTTP)連接的安全傳輸機制的支持,並採用適當的身份驗證模式

身份驗證與授權安全性

當前的安全挑戰

現代 MCP 實作面臨多種身份驗證與授權挑戰:

風險與威脅向量

  • 授權邏輯配置錯誤:MCP 伺服器中的授權實作缺陷可能導致敏感數據暴露並錯誤地應用訪問控制
  • OAuth 令牌洩露:本地 MCP 伺服器令牌被盜,攻擊者可冒充伺服器並訪問下游服務
  • 令牌傳遞漏洞:不當的令牌處理會導致安全控制繞過和責任缺失
  • 過度權限:過度授權的 MCP 伺服器違反最小權限原則,擴大了攻擊面

令牌傳遞:一個關鍵的反模式

令牌傳遞在當前 MCP 授權規範中被明確禁止,因為其帶來嚴重的安全影響:

安全控制繞過
  • MCP 伺服器和下游 API 實作的關鍵安全控制(如速率限制、請求驗證、流量監控)依賴於正確的令牌驗證
  • 直接的客戶端到 API 令牌使用繞過了這些基本保護措施,削弱了安全架構
責任與審計挑戰
  • MCP 伺服器無法區分使用上游發行令牌的客戶端,破壞了審計追蹤
  • 下游資源伺服器日誌顯示的請求來源誤導,無法反映實際的 MCP 伺服器中介
  • 事件調查和合規審計變得更加困難
數據外洩風險
  • 未經驗證的令牌聲明使得擁有被盜令牌的惡意行為者可以利用 MCP 伺服器作為代理進行數據外洩
  • 信任邊界的違反允許未授權的訪問模式繞過預期的安全控制
多服務攻擊向量
  • 被盜令牌被多個服務接受,允許在連接系統之間進行橫向移動
  • 當令牌來源無法驗證時,服務之間的信任假設可能被破壞

安全控制與緩解措施

關鍵安全要求:

強制性:MCP 伺服器 必須禁止 接受任何未明確為 MCP 伺服器發行的令牌

身份驗證與授權控制

訪問控制實作

  • 最小權限原則:僅授予 MCP 伺服器執行預期功能所需的最低權限

  • 基於角色的訪問控制(RBAC):實作細粒度的角色分配

    • 將角色範圍嚴格限定於特定資源和操作
    • 避免擴大攻擊面的廣泛或不必要的權限
  • 持續的權限監控:實作持續的訪問審核和監控

    • 監控權限使用模式是否存在異常
    • 及時修正過度或未使用的權限

AI 特定的安全威脅

提示注入與工具操控攻擊

現代 MCP 實作面臨傳統安全措施無法完全應對的複雜 AI 特定攻擊向量:

間接提示注入(跨域提示注入)

間接提示注入 是 MCP 支援的 AI 系統中最關鍵的漏洞之一。攻擊者將惡意指令嵌入外部內容(如文件、網頁、電子郵件或數據來源),AI 系統隨後將其處理為合法指令。

攻擊場景:

  • 基於文件的注入:惡意指令隱藏在處理的文件中,觸發意外的 AI 行為
  • 網頁內容利用:被攻擊的網頁包含嵌入的提示,當被抓取時操控 AI 行為
  • 基於電子郵件的攻擊:電子郵件中的惡意提示導致 AI 助手洩露資訊或執行未授權操作
  • 數據來源污染:被攻擊的數據庫或 API 向 AI 系統提供受污染的內容

實際影響:這些攻擊可能導致數據外洩、隱私洩露、有害內容生成以及用戶互動操控。詳細分析請參閱 MCP 中的提示注入(Simon Willison)

提示注入攻擊圖示

工具中毒攻擊

工具中毒 針對定義 MCP 工具的元數據,利用 LLM 解釋工具描述和參數的方式來決定執行行為。

攻擊機制:

  • 元數據操控:攻擊者將惡意指令注入工具描述、參數定義或使用範例中
  • 隱形指令:工具元數據中隱藏的提示,AI 模型會處理但人類用戶無法察覺
  • 動態工具修改("地毯拉動"):用戶批准的工具後續被修改以執行惡意行為
  • 參數注入:工具參數結構中嵌入的惡意內容影響模型行為

託管伺服器風險:遠端 MCP 伺服器風險更高,因為工具定義可以在用戶初次批准後更新,導致原本安全的工具變得惡意。詳細分析請參閱 工具中毒攻擊(Invariant Labs)

工具注入攻擊圖示

其他 AI 攻擊向量

  • 跨域提示注入(XPIA):利用多個域的內容繞過安全控制的複雜攻擊
  • 動態能力修改:實時更改工具能力,逃避初始安全評估
  • 上下文窗口污染:操控大型上下文窗口以隱藏惡意指令
  • 模型混淆攻擊:利用模型限制創造不可預測或不安全的行為

AI 安全風險影響

高影響後果:

  • 數據外洩:未授權訪問和竊取敏感企業或個人數據
  • 隱私洩露:暴露個人身份資訊(PII)和機密商業數據
  • 系統操控:對關鍵系統和工作流程的非預期修改
  • 憑證盜竊:身份驗證令牌和服務憑證的洩露
  • 橫向移動:利用受損的 AI 系統作為進一步網路攻擊的跳板

Microsoft AI 安全解決方案

AI Prompt Shields:針對注入攻擊的高級保護

Microsoft AI Prompt Shields 通過多層安全防護提供針對直接和間接提示注入攻擊的全面防禦:

核心保護機制:
  1. 高級檢測與過濾

    • 機器學習算法和 NLP 技術檢測外部內容中的惡意指令
    • 實時分析文件、網頁、電子郵件和數據來源中的嵌入威脅
    • 合法與惡意提示模式的上下文理解
  2. 聚焦技術

    • 區分受信任的系統指令與可能受攻擊的外部輸入
    • 文本轉換方法增強模型相關性,同時隔離惡意內容
    • 幫助 AI 系統保持正確的指令層次結構,忽略注入的命令
  3. 分隔符與數據標記系統

    • 明確定義受信任系統消息與外部輸入文本之間的邊界
    • 特殊標記突出顯示受信任與不受信任數據來源之間的邊界
    • 清晰的分隔防止指令混淆和未授權命令執行
  4. 持續威脅情報

    • Microsoft 持續監控新興攻擊模式並更新防禦措施
    • 主動威脅狩獵以應對新的注入技術和攻擊向量
    • 定期更新安全模型以保持對演進威脅的有效性
  5. Azure Content Safety 整合

    • 作為 Azure AI Content Safety 套件的一部分
    • 額外檢測越獄嘗試、有害內容和安全政策違規
    • 在 AI 應用程式組件之間實現統一的安全控制

實作資源Microsoft Prompt Shields 文件

Microsoft Prompt Shields 保護

高級 MCP 安全威脅

會話劫持漏洞

會話劫持 是有狀態 MCP 實作中的一個關鍵攻擊向量,未授權方獲取並濫用合法的會話標識符,冒充客戶端執行未授權操作。

攻擊場景與風險

  • 會話劫持提示注入:攻擊者使用被盜的會話 ID 向共享會話狀態的伺服器注入惡意事件,可能觸發有害行為或訪問敏感數據
  • 直接冒充:被盜的會話 ID 允許直接呼叫 MCP 伺服器,繞過身份驗證,將攻擊者視為合法用戶
  • 受損的可恢復流:攻擊者可以提前終止請求,導致合法客戶端在恢復時可能處理惡意內容

會話管理的安全控制

關鍵要求:

  • 授權驗證:實作授權的 MCP 伺服器 **必須驗證所有入站
  • 安全會話生成:使用加密安全的非決定性會話 ID,並透過安全隨機數生成器生成
  • 用戶專屬綁定:將會話 ID 與用戶專屬資訊綁定,例如使用 <user_id>:<session_id> 格式,防止跨用戶會話濫用
  • 會話生命週期管理:實施適當的過期、輪換和失效機制,以縮短漏洞窗口
  • 傳輸安全:所有通信必須使用 HTTPS,防止會話 ID 被攔截

混淆代理問題

混淆代理問題發生在 MCP 伺服器作為客戶端與第三方服務之間的身份驗證代理時,可能因靜態客戶端 ID 的利用而導致授權繞過。

攻擊機制與風險

  • 基於 Cookie 的同意繞過:先前的用戶身份驗證會生成同意 Cookie,攻擊者可透過惡意授權請求和精心設計的重定向 URI 利用這些 Cookie
  • 授權碼竊取:現有的同意 Cookie 可能導致授權伺服器跳過同意畫面,將授權碼重定向到攻擊者控制的端點
  • 未經授權的 API 訪問:被竊取的授權碼可用於令牌交換,實現用戶冒充而無需明確批准

緩解策略

強制性控制措施:

  • 明確的同意要求:使用靜態客戶端 ID 的 MCP 代理伺服器必須為每個動態註冊的客戶端獲取用戶同意
  • OAuth 2.1 安全實施:遵循當前的 OAuth 安全最佳實踐,包括在所有授權請求中使用 PKCE(Proof Key for Code Exchange)
  • 嚴格的客戶端驗證:對重定向 URI 和客戶端標識符進行嚴格驗證,防止被利用

令牌透傳漏洞

令牌透傳是一種明確的反模式,MCP 伺服器接受未經適當驗證的客戶端令牌並將其轉發到下游 API,違反 MCP 授權規範。

安全影響

  • 控制繞過:直接的客戶端到 API 令牌使用繞過了關鍵的速率限制、驗證和監控控制
  • 審計記錄損壞:上游發行的令牌使得無法識別客戶端,破壞事件調查能力
  • 基於代理的數據外洩:未經驗證的令牌使惡意行為者能利用伺服器作為代理進行未授權的數據訪問
  • 信任邊界違反:當令牌來源無法驗證時,下游服務的信任假設可能被破壞
  • 多服務攻擊擴展:被攻擊的令牌在多個服務中被接受,可能導致橫向移動

必要的安全控制

不可妥協的要求:

  • 令牌驗證:MCP 伺服器不得接受未明確為 MCP 伺服器發行的令牌
  • 受眾驗證:始終驗證令牌的受眾聲明是否與 MCP 伺服器的身份匹配
  • 正確的令牌生命週期:實施短期訪問令牌並採用安全的輪換機制

AI 系統的供應鏈安全

供應鏈安全已超越傳統軟體依賴,涵蓋整個 AI 生態系統。現代 MCP 實現必須嚴格驗證和監控所有與 AI 相關的組件,因為每個組件都可能引入潛在漏洞,危及系統完整性。

擴展的 AI 供應鏈組件

傳統軟體依賴:

  • 開源庫和框架
  • 容器映像和基礎系統
  • 開發工具和構建管道
  • 基礎設施組件和服務

AI 特定的供應鏈元素:

  • 基礎模型:來自不同提供商的預訓練模型,需要進行來源驗證
  • 嵌入服務:外部向量化和語義搜索服務
  • 上下文提供者:數據來源、知識庫和文檔存儲庫
  • 第三方 API:外部 AI 服務、ML 管道和數據處理端點
  • 模型工件:權重、配置和微調模型變體
  • 訓練數據來源:用於模型訓練和微調的數據集

全面的供應鏈安全策略

組件驗證與信任

  • 來源驗證:在整合之前驗證所有 AI 組件的來源、許可和完整性
  • 安全評估:對模型、數據來源和 AI 服務進行漏洞掃描和安全審查
  • 聲譽分析:評估 AI 服務提供商的安全記錄和實踐
  • 合規驗證:確保所有組件符合組織的安全和法規要求

安全部署管道

  • 自動化 CI/CD 安全:在自動化部署管道中整合安全掃描
  • 工件完整性:對所有部署的工件(代碼、模型、配置)實施加密驗證
  • 分階段部署:使用漸進式部署策略,並在每個階段進行安全驗證
  • 可信工件存儲庫:僅從已驗證的安全工件註冊表和存儲庫中部署

持續監控與響應

  • 依賴掃描:對所有軟體和 AI 組件依賴進行持續漏洞監控
  • 模型監控:持續評估模型行為、性能漂移和安全異常
  • 服務健康追蹤:監控外部 AI 服務的可用性、安全事件和政策變更
  • 威脅情報整合:納入針對 AI 和 ML 安全風險的威脅信息

訪問控制與最小權限

  • 組件級別權限:根據業務需求限制對模型、數據和服務的訪問
  • 服務帳戶管理:實施專用服務帳戶,並僅授予最低必要權限
  • 網絡分段:隔離 AI 組件並限制服務之間的網絡訪問
  • API 閘道控制:使用集中式 API 閘道來控制和監控對外部 AI 服務的訪問

事件響應與恢復

  • 快速響應程序:建立針對受損 AI 組件的修補或替換流程
  • 憑證輪換:自動化系統,用於輪換密鑰、API 金鑰和服務憑證
  • 回滾能力:能夠快速恢復到先前已知的良好版本的 AI 組件
  • 供應鏈漏洞恢復:針對上游 AI 服務受損的特定響應程序

Microsoft 安全工具與整合

GitHub Advanced Security 提供全面的供應鏈保護,包括:

  • 密鑰掃描:自動檢測存儲庫中的憑證、API 金鑰和令牌
  • 依賴掃描:對開源依賴和庫進行漏洞評估
  • CodeQL 分析:靜態代碼分析,用於檢測安全漏洞和代碼問題
  • 供應鏈洞察:提供對依賴健康狀況和安全狀態的可見性

Azure DevOps 與 Azure Repos 整合:

  • 在 Microsoft 開發平台中無縫整合安全掃描
  • 在 Azure Pipelines 中對 AI 工作負載進行自動化安全檢查
  • 強制執行安全的 AI 組件部署策略

Microsoft 內部實踐:
Microsoft 在所有產品中實施了廣泛的供應鏈安全實踐。了解更多經驗,請參閱 The Journey to Secure the Software Supply Chain at Microsoft

基礎安全最佳實踐

MCP 實現繼承並建立在組織現有的安全基礎之上。加強基礎安全實踐將顯著提升 AI 系統和 MCP 部署的整體安全性。

核心安全基礎

安全開發實踐

  • OWASP 合規:防範 OWASP Top 10 網頁應用程式漏洞
  • AI 特定保護:實施針對 OWASP Top 10 for LLMs 的控制措施
  • 安全密鑰管理:使用專用保險庫存儲令牌、API 金鑰和敏感配置數據
  • 端到端加密:在所有應用程式組件和數據流中實施安全通信
  • 輸入驗證:對所有用戶輸入、API 參數和數據來源進行嚴格驗證

基礎設施強化

  • 多因素身份驗證:所有管理和服務帳戶必須啟用 MFA
  • 補丁管理:對操作系統、框架和依賴進行自動化及時的補丁更新
  • 身份提供者整合:通過企業身份提供者(Microsoft Entra ID、Active Directory)進行集中身份管理
  • 網絡分段:對 MCP 組件進行邏輯隔離,限制橫向移動的可能性
  • 最小權限原則:為所有系統組件和帳戶授予最低必要權限

安全監控與檢測

  • 全面日誌記錄:詳細記錄 AI 應用程式活動,包括 MCP 客戶端與伺服器的交互
  • SIEM 整合:集中式安全信息和事件管理,用於異常檢測
  • 行為分析:使用 AI 驅動的監控檢測系統和用戶行為中的異常模式
  • 威脅情報:整合外部威脅信息和妥協指標(IOCs)
  • 事件響應:明確定義的安全事件檢測、響應和恢復程序

零信任架構

  • 永不信任,始終驗證:對用戶、設備和網絡連接進行持續驗證
  • 微分段:對單個工作負載和服務進行精細的網絡控制
  • 基於身份的安全:基於已驗證的身份而非網絡位置制定安全策略
  • 持續風險評估:根據當前上下文和行為動態評估安全狀態
  • 條件訪問:根據風險因素、位置和設備信任動態調整訪問控制

企業整合模式

Microsoft 安全生態系統整合

  • Microsoft Defender for Cloud:全面的雲安全狀態管理
  • Azure Sentinel:雲原生 SIEM 和 SOAR 功能,用於保護 AI 工作負載
  • Microsoft Entra ID:企業身份和訪問管理,支持條件訪問策略
  • Azure Key Vault:集中式密鑰管理,支持硬體安全模組(HSM)
  • Microsoft Purview:針對 AI 數據來源和工作流的數據治理與合規

合規與治理

  • 法規對齊:確保 MCP 實現符合行業特定的合規要求(GDPR、HIPAA、SOC 2)
  • 數據分類:正確分類和處理 AI 系統處理的敏感數據
  • 審計記錄:提供全面的日誌記錄以滿足法規合規和取證調查需求
  • 隱私控制:在 AI 系統架構中實施隱私設計原則
  • 變更管理:針對 AI 系統修改進行正式的安全審查流程

這些基礎實踐建立了堅實的安全基線,增強了 MCP 特定安全控制的有效性,並為 AI 驅動的應用程式提供全面保護。

關鍵安全要點

  • 分層安全方法:結合基礎安全實踐(安全編碼、最小權限、供應鏈驗證、持續監控)與 AI 特定控制措施,實現全面保護

  • AI 特定威脅格局:MCP 系統面臨獨特風險,包括提示注入、工具中毒、會話劫持、混淆代理問題、令牌透傳漏洞和過度權限,需採取專門的緩解措施

  • 身份驗證與授權卓越:實施使用外部身份提供者(Microsoft Entra ID)的強大身份驗證,強制執行正確的令牌驗證,並且絕不接受未明確為 MCP 伺服器發行的令牌

  • AI 攻擊防範:部署 Microsoft Prompt Shields 和 Azure Content Safety,防禦間接提示注入和工具中毒攻擊,同時驗證工具元數據並監控動態變更

  • 會話與傳輸安全:使用加密安全的非決定性會話 ID,並與用戶身份綁定,實施適當的會話生命週期管理,且絕不使用會話進行身份驗證

  • OAuth 安全最佳實踐:通過對動態註冊客戶端的明確用戶同意、正確的 OAuth 2.1 實施(包括 PKCE)以及嚴格的重定向 URI 驗證,防止混淆代理攻擊

  • 令牌安全原則:避免令牌透傳反模式,驗證令牌受眾聲明,實施短期令牌並進行安全輪換,保持清晰的信任邊界

  • 全面的供應鏈安全:將所有 AI 生態系統組件(模型、嵌入、上下文提供者、外部 API)視為傳統軟體依賴,並採取相同的安全嚴謹性

  • 持續演進:緊跟快速演變的 MCP 規範,為安全社區標準做出貢獻,並隨著協議的成熟保持適應性安全姿態

  • Microsoft 安全整合:利用 Microsoft 的全面安全生態系統(Prompt Shields、Azure Content Safety、GitHub Advanced Security、Entra ID),增強 MCP 部署的保護

全面資源

官方 MCP 安全文檔

安全標準與最佳實踐

AI 安全研究與分析

Microsoft 安全解決方案

實施指南與教程

DevOps 與供應鏈安全

額外的安全文件

欲獲取全面的安全指導,請參考本節中的專業文件:


下一步

下一步:第 3 章:入門指南

免責聲明
本文件使用 AI 翻譯服務 Co-op Translator 進行翻譯。我們致力於提供準確的翻譯,但請注意,自動翻譯可能包含錯誤或不準確之處。應以原始語言的文件作為權威來源。對於關鍵資訊,建議尋求專業人工翻譯。我們對因使用此翻譯而產生的任何誤解或錯誤解讀概不負責。