Fenced Frame 總覽

安全地將內容嵌入網頁,不必分享跨網站資料。

導入狀態

本文將介紹新的 HTML 元素:<fencedframe>

提案 状态
将 urn 更改为 config 的 Web API 变更
说明
2023 年第 1 季度在 Chrome 中提供。
围栏框架中的广告素材宏用于广告报告 (FFAR)
GitHub 问题
将于 2023 年第 3 季度在 Chrome 中提供。
一次发送自动信标
GitHub 问题
将于 2023 年第 3 季度在 Chrome 中推出。
可序列化的围栏帧配置
GitHub 问题
将于 2023 年第 3 季度在 Chrome 中提供。
针对 Protected Audience 广告尺寸宏的其他格式选项
GitHub 问题
2023 年第 4 季度在 Chrome 中提供。
自动向所有已注册网址发送信标
GitHub 问题 | GitHub 问题
2023 年第 4 季度在 Chrome 中提供。
启用从 Urn iFrame 和广告组件框架中退出广告兴趣群组的功能
GitHub 问题
2024 年第 1 季度在 Chrome 中推出
引入了 reserved.top_navigation_start/commit
GitHub 问题GitHub 问题
2024 年第 1 季度在 Chrome 中推出
在 3PCD 之前,请勿在 ReportEvent 中停用 Cookie 设置
GitHub 问题
2024 年第 1 季度在 Chrome 中推出
添加对跨源子框架中的自动信标的支持
GitHub 问题
2024 年第 1 季度在 Chrome 中推出
允许跨源子帧发送 reportEvent() 信标
GitHub 问题
2024 年第 2 季度在 Chrome 中推出

為什麼需要使用柵欄影格?

Fenced Frame (<fencedframe>) 是用於嵌入內容的 HTML 元素,類似於 iframe。與 iframe 不同,fenced frame 會限制與其嵌入內容的通訊,讓框架可以存取跨網站資料,但不會與嵌入內容共用資料。部分 Privacy Sandbox API 可能要求選取的文件在受限框架內顯示

同樣地,嵌入內容中的任何第一方資料都無法與受限影格共用。

舉例來說,如果 news.example (嵌入內容) 在受限影格中嵌入來自 shoes.example 的廣告,news.example 就無法從 shoes.example 廣告中擷取資料,而 shoes.example 也無法從 news.example 中學習第一方資料。

透過儲存空間分區強化跨網站隱私

瀏覽網頁時,您可能會在某個網站上查看產品,然後在完全不同的網站上看到這些產品的廣告。

目前,這項廣告技術主要透過追蹤技術達成,使用第三方 Cookie 在不同網站之間分享資訊。

Chrome 正在開發儲存空間區隔功能,可將瀏覽器儲存空間分隔為個別網站。如果沒有分區,當 shoes.example 的 iframe 嵌入 news.example,且該 iframe 將值儲存在儲存空間時,系統就能從 shoes.example 網站讀取該值。儲存空間已劃分後,跨網站 iframe 就不會再共用儲存空間,因此 shoes.example 將無法存取 iframe 儲存的資訊。如果 iframe 是從 *.shoes.example 提供並嵌入 *.shoes.example,瀏覽器儲存空間會共用,因為這些資源屬於同網站

比較儲存空間分割前後的狀態。

儲存空間區隔功能將套用至 LocalStorage、IndexedDB 和 Cookie 等標準儲存空間 API。在分區的世界中,第一方儲存空間的資訊外洩情形將大幅減少。

使用跨網站資料

分隔框架是 Privacy Sandbox 功能,建議頂層網站應分割資料。許多 Privacy Sandbox 提案和 API 的目標,是在不使用第三方 Cookie 或其他追蹤機制的情況下,滿足跨網站用途。例如:

區隔框架的設計可搭配 Protected Audience API 使用。導入 Protected Audience API 後,使用者的興趣會以興趣群組的形式註冊在廣告主網站上,並顯示可能符合使用者興趣的廣告。接著,在另一個網站 (稱為「發布商」) 上,系統會對在相關興趣群組中註冊的廣告進行競價,並在受保護的框架中顯示勝出的廣告。

如果發布商在 iframe 中顯示得標廣告,且指令碼可讀取 iframe 的 src 屬性,發布商就能根據該廣告的網址推斷訪客的興趣。這並非隱私保護機制。

使用圍欄框架後,發布商就能顯示符合訪客興趣的廣告,但只有框架中的廣告客戶會知道 src 和興趣群組。發布端無法存取這項資訊。

柵欄框架的運作方式為何?

區隔的畫面會使用 FencedFrameConfig 物件進行導覽。這個物件可從 Protected Audience API 競價或 Shared Storage 的網址選取作業傳回。接著,將設定物件設為圍欄邊框元素的 config 屬性。這與 iframe 不同,後者會將網址或不透明的 URN 指派給 src 屬性。FencedFrameConfig 物件具有唯讀的 url 屬性;不過,由於目前的用途需要隱藏內部資源的實際網址,因此這個屬性在讀取時會傳回字串 opaque

Fenced Frame 無法使用 postMessage 與嵌入者通訊。不過,受限區塊可以使用 postMessage,並在受限區塊內使用 iframe。

隔離的畫面會以其他方式與發布端隔離。舉例來說,發布商無法存取受限框架內的 DOM,而受限框架也無法存取發布商的 DOM。此外,name 這類屬性可設為任何值,並由發布者觀察,但在受限畫面中則無法使用。

柵欄式影格會像頂層瀏覽內容 (例如瀏覽器分頁) 一樣運作。雖然特定用途 (例如 opaque-ads) 中的隔離框架可包含跨網站資料 (例如 Protected Audience API 興趣群組),但該框架無法存取未分割的儲存空間或 Cookie。opaque-ads 區隔框架可以存取不重複的 nonce 類型 Cookie 和儲存空間區隔。

說明文件進一步說明圍欄框架的特性。

柵欄式框架與 iframe 有何差異?

瞭解了柵欄框架的功能和限制後,不妨比較一下現有的 iframe 功能。

功能 iframe fencedframe
嵌入內容
嵌入的內容可存取嵌入內容的 DOM
嵌入內容的上下文可存取嵌入內容的 DOM
可觀察的屬性,例如 name
網址 (http://example.com) 是 (視用途而定)
由瀏覽器管理的非公開來源 (urn:uuid)
存取跨網站資料 是 (視用途而定)

為了保護隱私權,圍欄式邊框支援的外部通訊選項較少。

是否會以柵欄式框架取代 iframe?

最終,柵欄框架不會取代 iframe,您也不需要使用柵欄框架。當需要在同一頁面上顯示不同頂層區塊的資料時,使用區隔框架可提供更私密的框架。

同網域 iframe (有時稱為友善 iframe) 視為可信內容。

使用圍欄頁框

隔離的框架會與其他 Privacy Sandbox API 搭配使用,在單一頁面中顯示來自不同儲存空間分區的文件。我們正在討論可能的 API。

目前這個組合的候選人包括:

詳情請參閱Fenced Frames 使用情境說明

範例

如要取得圍欄框架 config 物件,您必須將 resolveToConfig: true 傳入 Protected Audience API 的 runAdAuction() 呼叫或 Shared Storage 的 selectURL() 呼叫。如果未新增屬性 (或設為 false),產生的承諾會解析為只能在 iframe 中使用的 URN。

從 Protected Audience API 競價取得柵欄框架設定
const frameConfig = await navigator.runAdAuction({
  // ...auction configuration
  resolveToConfig: true
});
從共用儲存空間網址選項取得柵欄式影格設定
const frameConfig = await sharedStorage.selectURL('operation-name', {
  resolveToConfig: true
});

取得設定後,您可以將其指派給受限影格 config 屬性,讓影格導向設定所代表的資源。早期版本的 Chrome 不支援 resolveToConfig 屬性,因此您仍必須在導覽前確認承諾已解析為 FencedFrameConfig

將 config 設為 fenced frame 屬性
if (window.FencedFrameConfig && frameConfig instanceof FencedFrameConfig) {
  const frame = document.createElement('fencedframe');
  frame.config = frameConfig;
}

詳情請參閱「圍欄框架」和「圍欄框架設定」說明。

標頭

瀏覽器會為來自受限影格和嵌入受限影格內的 iframe 的要求設定 Sec-Fetch-Dest: fencedframe

Sec-Fetch-Dest: fencedframe

伺服器必須為要在受限頁框中載入的文件設定 Supports-Loading-Mode: fenced-frame 回應標頭。標頭也必須出現在受限頁框內的所有 iframe 中。

Supports-Loading-Mode: fenced-frame

共用儲存空間內容

您可以使用私人匯總功能,在與嵌入者相關聯的區隔框架中,回報事件層級資料。使用 fencedFrameConfig.setSharedStorageContext() 方法,您可以將部分內容相關資料 (例如事件 ID) 從嵌入者傳遞至由 Protected Audience API 啟動的共用儲存空間工作項。

在下列範例中,我們會在共用儲存空間中儲存嵌入頁面可用的部分資料,以及在圍欄框架中可用的部分資料。在嵌入者頁面中,模擬事件 ID 會設為共用儲存空間內容。從圍欄影格傳入影格事件資料。

您可以在內嵌頁面中,將內容相關資料設為共用儲存空間內容:

const frameConfig = await navigator.runAdAuction({ resolveToConfig: true });

// Data from the embedder that you want to pass to the shared storage worklet
frameConfig.setSharedStorageContext('some-event-id');

const frame = document.createElement('fencedframe');
frame.config = frameConfig;

您可以從圍欄框架將事件層級資料傳入共用儲存空間工作區 (與上方嵌入器的內容相關資料無關):

const frameData = {
  // Data available only inside the fenced frame
}

await window.sharedStorage.worklet.addModule('reporting-worklet.js');

await window.sharedStorage.run('send-report', {
  data: {
    frameData
  },
});

您可以從 sharedStorage.context 讀取嵌入者的內容相關資訊,以及從 data 物件讀取框架的事件層級資料,然後透過私人匯總功能回報:

class ReportingOperation {
  convertEventIdToBucket(eventId) { ... }
  convertEventPayloadToValue(info) { ... }

  async run(data) {
    // Data from the embedder
    const eventId = sharedStorage.context;

    // Data from the fenced frame
    const eventPayload = data.frameData;

    privateAggregation.contributeToHistogram({
      bucket: convertEventIdToBucket(eventId),
      value: convertEventPayloadToValue(eventPayload)
    });
  }
}

register('send-report', ReportingOperation);

如要進一步瞭解在受限影格設定物件中嵌入者使用的內容,請參閱說明文件

試用圍欄頁框

使用 Chrome 旗標,在 chrome://flags/#enable-fenced-frames 啟用 Fenced Frame API。

在 Chrome 實驗中,將「啟用 Fenced 框架元素」標記設為「已啟用」

對話方塊中有多個選項。強烈建議您選取「啟用」,讓 Chrome 在可用新架構時自動更新。

其他選項「Enabled with ShadowDOM」和「Enabled with multiple page architecture」則提供不同的實作策略,僅與瀏覽器工程師相關。目前,啟用的運作方式與透過 ShadowDOM 啟用相同。日後,「啟用」會對應至「啟用多頁架構」

特徵偵測

如要判斷是否已定義圍欄影格,請按照下列步驟操作:

if (window.HTMLFencedFrameElement) {
  // The fenced frame element is defined
}

如要判斷是否可使用圍欄框架設定,請執行下列操作: js if (window.FencedFrameConfig && frameConfig instanceof FencedFrameConfig) { // The fenced frame config is available }

瀏覽器支援

互動並分享意見回饋

我們正積極討論圍欄框架,日後可能會有變動。如果您試用這個 API 後有任何意見,歡迎與我們分享。

瞭解詳情