chrome.browsingData

說明

使用 chrome.browsingData API 從使用者本機設定檔移除瀏覽資料。

權限

browsingData

您必須在擴充功能資訊清單中宣告 "browsingData" 權限,才能使用這個 API。

{
  "name": "My extension",
  ...
  "permissions": [
    "browsingData",
  ],
  ...
}

概念和用法

這個 API 最簡單的用途是清除使用者的瀏覽資料,以時間為依據。 程式碼應提供時間戳記,指出應在哪一天過後移除使用者的瀏覽資料。這個時間戳記採用自 Unix 紀元以來的毫秒數格式 (可使用 getTime() 方法從 JavaScript Date 物件擷取)。

舉例來說,如要清除使用者在上週的所有瀏覽資料,您可以編寫程式碼,如下所示:

var callback = function () {
  // Do something clever here once data has been removed.
};

var millisecondsPerWeek = 1000 * 60 * 60 * 24 * 7;
var oneWeekAgo = (new Date()).getTime() - millisecondsPerWeek;
chrome.browsingData.remove({
  "since": oneWeekAgo
}, {
  "appcache": true,
  "cache": true,
  "cacheStorage": true,
  "cookies": true,
  "downloads": true,
  "fileSystems": true,
  "formData": true,
  "history": true,
  "indexedDB": true,
  "localStorage": true,
  "passwords": true,
  "serviceWorkers": true,
  "webSQL": true
}, callback);

chrome.browsingData.remove() 方法可讓您透過單一呼叫移除各種類型的瀏覽資料,速度比呼叫多個更具體的方法更快。然而,如果您只想清除一種特定類型的瀏覽資料 (例如 Cookie),那麼更精細的方法會提供可讀取的替代方案,而不是以 JSON 格式填入的呼叫。

var callback = function () {
  // Do something clever here once data has been removed.
};

var millisecondsPerWeek = 1000 * 60 * 60 * 24 * 7;
var oneWeekAgo = (new Date()).getTime() - millisecondsPerWeek;
chrome.browsingData.removeCookies({
  "since": oneWeekAgo
}, callback);

如果使用者正在同步處理資料,chrome.browsingData.remove() 可能會在清除同步功能後,自動為同步帳戶重建 Cookie。這是確保同步功能能繼續運作,以便最終在伺服器上刪除資料。不過,如果使用更具體的 chrome.browsingData.removeCookies() 來清除同步帳戶的 Cookie,則系統會暫停同步處理。

特定來源

如要移除特定來源的資料,或排除一組來源而將其刪除,您可以使用 RemovalOptions.originsRemovalOptions.excludeOrigins 參數。這類中繼資料只能套用於 Cookie、快取和儲存空間 (CacheStorage、FileSystems、IndexedDB、LocalStorage、ServiceWorkers 和 WebSQL)。

chrome.browsingData.remove({
  "origins": ["https://www.example.com"]
}, {
  "cacheStorage": true,
  "cookies": true,
  "fileSystems": true,
  "indexedDB": true,
  "localStorage": true,
  "serviceWorkers": true,
  "webSQL": true
}, callback);

來源類型

在 API 選項物件中加入 originTypes 屬性,即可指定要套用哪些類型的來源。來源可分為三個類別:

  • unprotectedWeb 涵蓋使用者造訪網站的一般情況,且不會採取任何特殊動作。如未指定 originTypes,API 會預設移除未受保護的網路來源中的資料。
  • protectedWeb 涵蓋已安裝為代管應用程式的網路來源。舉例來說,安裝 Angry Birds 可保護來源 https://chrome.angrybirds.com,並將其從 unprotectedWeb 類別中移除。觸發這些來源的資料刪除作業時,請務必謹慎,務必讓使用者瞭解收到的內容,因為這項操作無法復原。沒有人想花更常從事小豬房屋。
  • extension 包含 chrome-extensions: 配置下的來源。移除擴充功能資料時,請務必謹慎小心。

我們可以調整前一個範例,只移除受保護網站的資料,方法如下:

var callback = function () {
  // Do something clever here once data has been removed.
};

var millisecondsPerWeek = 1000 * 60 * 60 * 24 * 7;
var oneWeekAgo = (new Date()).getTime() - millisecondsPerWeek;
chrome.browsingData.remove({
  "since": oneWeekAgo,
  "originTypes": {
    "protectedWeb": true
  }
}, {
  "appcache": true,
  "cache": true,
  "cacheStorage": true,
  "cookies": true,
  "downloads": true,
  "fileSystems": true,
  "formData": true,
  "history": true,
  "indexedDB": true,
  "localStorage": true,
  "passwords": true,
  "serviceWorkers": true,
  "webSQL": true
}, callback);

示例

如要試用這個 API,請從 chrome-extension-samples 存放區安裝 browsingData API 範例

類型

DataTypeSet

一組資料類型。缺少的資料類型會解譯為 false

屬性

  • 應用程式快取

    布林值 選填

    網站的應用程式快取。

  • 快取

    布林值 選填

    瀏覽器的快取。

  • cacheStorage

    布林值 選填

    Chrome 72 以上版本

    快取儲存空間

  • Google Cloud 網站上的 Cookie

    布林值 選填

    瀏覽器的 Cookie。

  • 下載內容

    布林值 選填

    瀏覽器的下載清單。

  • fileSystems

    布林值 選填

    網站的檔案系統。

  • formData

    布林值 選填

    瀏覽器的表單資料。

  • 歷史

    布林值 選填

    瀏覽器的歷史記錄。

  • indexedDB

    布林值 選填

    網站的索引資料庫資料。

  • localStorage

    布林值 選填

    網站的本機儲存空間資料。

  • 密碼

    布林值 選填

    已儲存密碼。

  • pluginData

    布林值 選填

    自 Chrome 88 版起已淘汰

    已停止支援 Flash。系統會忽略這個資料類型。

    外掛程式的資料。

  • serverBoundCertificates

    布林值 選填

    自 Chrome 76 版起已淘汰

    已停止支援伺服器繫結憑證。系統會忽略這個資料類型。

    伺服器繫結憑證。

  • serviceWorkers

    布林值 選填

    Service Worker。

  • webSQL

    布林值 選填

    網站的 WebSQL 資料。

RemovalOptions

用於決定要移除哪些資料的選項。

屬性

  • excludeOrigins

    string[] 選填

    Chrome 74 以上版本

    如有設定,系統就不會刪除這份清單中的來源資料。無法與 origins 搭配使用。僅支援 Cookie、儲存空間和快取。系統會排除整個可註冊網域的 Cookie。

  • originTypes

    物件 optional

    該物件的屬性會指定要清除哪些來源類型。如未指定,這個物件會預設為僅清除「未受保護的」來源。請務必先確認您要移除應用程式資料,再新增「 ProtectedWeb」或「extensions」。

    • 擴充功能

      布林值 選填

      使用者安裝的擴充功能和封裝應用程式 (請「謹慎」!)

    • protectedWeb

      布林值 選填

      以代管應用程式形式安裝的網站 (請小心!)。

    • unprotectedWeb

      布林值 選填

      一般網站。

  • 起源

    [string, ...string[]] optional

    Chrome 74 以上版本

    當出現時,系統只會刪除這份清單中來源的資料。僅支援 Cookie、儲存空間和快取。已清除整個可註冊網域的 Cookie。

  • 開始於

    編號 選填

    移除這個日期當天或之後累積的資料,以自紀元以來的毫秒數表示 (透過 JavaScript Date 物件的 getTime 方法存取)。如果沒有,則預設為 0 (會移除所有瀏覽資料)。

方法

remove()

Promise
chrome.browsingData.remove(
  options: RemovalOptions,
  dataToRemove: DataTypeSet,
  callback?: function,
)

清除使用者設定檔中儲存的各種瀏覽資料類型。

參數

  • dataToRemove

    要移除的資料類型組合。

  • 回呼

    函式 選用

    callback 參數如下所示:

    () => void

傳回

  • Promise<void>

    Chrome 96 以上版本

    Promise 適用於 Manifest V3 及以上版本,但為了回溯相容性,提供回呼。您無法在同一函式呼叫中同時使用兩者。保證會以傳遞至回呼的類型來解析。

removeAppcache()

Promise
chrome.browsingData.removeAppcache(
  options: RemovalOptions,
  callback?: function,
)

清除網站的應用程式快取資料。

參數

  • 回呼

    函式 選用

    callback 參數如下所示:

    () => void

傳回

  • Promise<void>

    Chrome 96 以上版本

    Promise 適用於 Manifest V3 及以上版本,但為了回溯相容性,提供回呼。您無法在同一函式呼叫中同時使用兩者。保證會以傳遞至回呼的類型來解析。

removeCache()

Promise
chrome.browsingData.removeCache(
  options: RemovalOptions,
  callback?: function,
)

清除瀏覽器的快取。

參數

  • 回呼

    函式 選用

    callback 參數如下所示:

    () => void

傳回

  • Promise<void>

    Chrome 96 以上版本

    Promise 適用於 Manifest V3 及以上版本,但為了回溯相容性,提供回呼。您無法在同一函式呼叫中同時使用兩者。保證會以傳遞至回呼的類型來解析。

removeCacheStorage()

Promise Chrome 72 以上版本
chrome.browsingData.removeCacheStorage(
  options: RemovalOptions,
  callback?: function,
)

清除網站的快取儲存空間資料。

參數

  • 回呼

    函式 選用

    callback 參數如下所示:

    () => void

傳回

  • Promise<void>

    Chrome 96 以上版本

    Promise 適用於 Manifest V3 及以上版本,但為了回溯相容性,提供回呼。您無法在同一函式呼叫中同時使用兩者。保證會以傳遞至回呼的類型來解析。

removeCookies()

Promise
chrome.browsingData.removeCookies(
  options: RemovalOptions,
  callback?: function,
)

清除特定時間範圍內修改的瀏覽器 Cookie 和伺服器繫結憑證。

參數

  • 回呼

    函式 選用

    callback 參數如下所示:

    () => void

傳回

  • Promise<void>

    Chrome 96 以上版本

    Promise 適用於 Manifest V3 及以上版本,但為了回溯相容性,提供回呼。您無法在同一函式呼叫中同時使用兩者。保證會以傳遞至回呼的類型來解析。

removeDownloads()

Promise
chrome.browsingData.removeDownloads(
  options: RemovalOptions,
  callback?: function,
)

清除瀏覽器的下載檔案清單 (「而非」下載的檔案)。

參數

  • 回呼

    函式 選用

    callback 參數如下所示:

    () => void

傳回

  • Promise<void>

    Chrome 96 以上版本

    Promise 適用於 Manifest V3 及以上版本,但為了回溯相容性,提供回呼。您無法在同一函式呼叫中同時使用兩者。保證會以傳遞至回呼的類型來解析。

removeFileSystems()

Promise
chrome.browsingData.removeFileSystems(
  options: RemovalOptions,
  callback?: function,
)

清除網站的檔案系統資料。

參數

  • 回呼

    函式 選用

    callback 參數如下所示:

    () => void

傳回

  • Promise<void>

    Chrome 96 以上版本

    Promise 適用於 Manifest V3 及以上版本,但為了回溯相容性,提供回呼。您無法在同一函式呼叫中同時使用兩者。保證會以傳遞至回呼的類型來解析。

removeFormData()

Promise
chrome.browsingData.removeFormData(
  options: RemovalOptions,
  callback?: function,
)

清除瀏覽器儲存的表單資料 (自動填入)。

參數

  • 回呼

    函式 選用

    callback 參數如下所示:

    () => void

傳回

  • Promise<void>

    Chrome 96 以上版本

    Promise 適用於 Manifest V3 及以上版本,但為了回溯相容性,提供回呼。您無法在同一函式呼叫中同時使用兩者。保證會以傳遞至回呼的類型來解析。

removeHistory()

Promise
chrome.browsingData.removeHistory(
  options: RemovalOptions,
  callback?: function,
)

清除瀏覽器的紀錄。

參數

  • 回呼

    函式 選用

    callback 參數如下所示:

    () => void

傳回

  • Promise<void>

    Chrome 96 以上版本

    Promise 適用於 Manifest V3 及以上版本,但為了回溯相容性,提供回呼。您無法在同一函式呼叫中同時使用兩者。保證會以傳遞至回呼的類型來解析。

removeIndexedDB()

Promise
chrome.browsingData.removeIndexedDB(
  options: RemovalOptions,
  callback?: function,
)

清除網站的索引資料庫資料。

參數

  • 回呼

    函式 選用

    callback 參數如下所示:

    () => void

傳回

  • Promise<void>

    Chrome 96 以上版本

    Promise 適用於 Manifest V3 及以上版本,但為了回溯相容性,提供回呼。您無法在同一函式呼叫中同時使用兩者。保證會以傳遞至回呼的類型來解析。

removeLocalStorage()

Promise
chrome.browsingData.removeLocalStorage(
  options: RemovalOptions,
  callback?: function,
)

清除網站的本機儲存空間資料。

參數

  • 回呼

    函式 選用

    callback 參數如下所示:

    () => void

傳回

  • Promise<void>

    Chrome 96 以上版本

    Promise 適用於 Manifest V3 及以上版本,但為了回溯相容性,提供回呼。您無法在同一函式呼叫中同時使用兩者。保證會以傳遞至回呼的類型來解析。

removePasswords()

Promise
chrome.browsingData.removePasswords(
  options: RemovalOptions,
  callback?: function,
)

清除瀏覽器儲存的密碼。

參數

  • 回呼

    函式 選用

    callback 參數如下所示:

    () => void

傳回

  • Promise<void>

    Chrome 96 以上版本

    Promise 適用於 Manifest V3 及以上版本,但為了回溯相容性,提供回呼。您無法在同一函式呼叫中同時使用兩者。保證會以傳遞至回呼的類型來解析。

removePluginData()

Promise 自 Chrome 88 版起已淘汰
chrome.browsingData.removePluginData(
  options: RemovalOptions,
  callback?: function,
)

已停止支援 Flash。這個函式不會產生任何作用。

清除外掛程式的資料。

參數

  • 回呼

    函式 選用

    callback 參數如下所示:

    () => void

傳回

  • Promise<void>

    Chrome 96 以上版本

    Promise 適用於 Manifest V3 及以上版本,但為了回溯相容性,提供回呼。您無法在同一函式呼叫中同時使用兩者。保證會以傳遞至回呼的類型來解析。

removeServiceWorkers()

Promise Chrome 72 以上版本
chrome.browsingData.removeServiceWorkers(
  options: RemovalOptions,
  callback?: function,
)

清除網站的 Service Worker。

參數

  • 回呼

    函式 選用

    callback 參數如下所示:

    () => void

傳回

  • Promise<void>

    Chrome 96 以上版本

    Promise 適用於 Manifest V3 及以上版本,但為了回溯相容性,提供回呼。您無法在同一函式呼叫中同時使用兩者。保證會以傳遞至回呼的類型來解析。

removeWebSQL()

Promise
chrome.browsingData.removeWebSQL(
  options: RemovalOptions,
  callback?: function,
)

清除網站的 WebSQL 資料。

參數

  • 回呼

    函式 選用

    callback 參數如下所示:

    () => void

傳回

  • Promise<void>

    Chrome 96 以上版本

    Promise 適用於 Manifest V3 及以上版本,但為了回溯相容性,提供回呼。您無法在同一函式呼叫中同時使用兩者。保證會以傳遞至回呼的類型來解析。

settings()

Promise
chrome.browsingData.settings(
  callback?: function,
)

目前在「清除瀏覽資料」設定使用者介面中選取的資料類型報告。注意:設定使用者介面不提供這個 API 中包含的某些資料類型。部分 UI 設定可控管這裡列出的多種資料類型。

參數

  • 回呼

    函式 選用

    callback 參數如下所示:

    (result: object) => void

    • 結果

      物件

      • dataRemovalPermitted

        所有型別都會在結果中顯示,如果允許移除 (例如根據企業政策),則值為 true;如果不允許,則值為 false

      • dataToRemove

        如果同時選取移除且允許移除,所有類型都會出現在結果中,如果同時選取 true,則會顯示 false

傳回

  • Promise<object>

    Chrome 96 以上版本

    Promise 適用於 Manifest V3 及以上版本,但為了回溯相容性,提供回呼。您無法在同一函式呼叫中同時使用兩者。保證會以傳遞至回呼的類型來解析。