chrome.browsingData

Deskripsi

Gunakan chrome.browsingData API untuk menghapus data penjelajahan dari profil lokal pengguna.

Izin

browsingData

Anda harus mendeklarasikan izin "browsingData" di manifes ekstensi untuk menggunakan API ini.

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

Konsep dan penggunaan

Kasus penggunaan paling sederhana untuk API ini adalah mekanisme berbasis waktu untuk menghapus data penjelajahan pengguna. Kode Anda harus memberikan stempel waktu yang menunjukkan tanggal historis setelah data penjelajahan pengguna harus dihapus. Stempel waktu ini diformat sebagai jumlah milidetik sejak epoch Unix (yang dapat diambil dari objek Date JavaScript menggunakan metode getTime()).

Misalnya, untuk menghapus semua data penjelajahan pengguna dari minggu lalu, Anda dapat menulis kode sebagai berikut:

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); 

Metode chrome.browsingData.remove() memungkinkan Anda menghapus berbagai jenis data penjelajahan dengan satu panggilan, dan akan jauh lebih cepat daripada memanggil beberapa metode yang lebih spesifik. Namun, jika Anda hanya ingin menghapus satu jenis data penjelajahan tertentu (misalnya, cookie), metode yang lebih terperinci menawarkan alternatif yang mudah dibaca untuk panggilan yang diisi dengan 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); 

Jika pengguna menyinkronkan datanya, chrome.browsingData.remove() dapat otomatis membangun ulang cookie untuk akun Sinkronisasi setelah menghapusnya. Hal ini dilakukan untuk memastikan bahwa Sinkronisasi dapat terus berfungsi, sehingga data dapat dihapus di server pada akhirnya. Namun, chrome.browsingData.removeCookies() yang lebih spesifik dapat digunakan untuk menghapus cookie akun Sinkronisasi, dan Sinkronisasi akan dijeda dalam kasus ini.

Asal spesifik

Untuk menghapus data untuk asal tertentu atau mengecualikan sekumpulan asal dari penghapusan, Anda dapat menggunakan parameter RemovalOptions.origins dan RemovalOptions.excludeOrigins. Kebijakan ini hanya dapat diterapkan ke cookie, cache, dan penyimpanan (CacheStorage, FileSystems, IndexedDB, LocalStorage, ServiceWorkers, dan WebSQL).

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

Jenis asal

Dengan menambahkan properti originTypes ke objek opsi API, Anda dapat menentukan jenis asal yang harus terpengaruh. Asal dibagi menjadi tiga kategori:

  • unprotectedWeb mencakup kasus umum situs yang dikunjungi pengguna tanpa melakukan tindakan khusus. Jika Anda tidak menentukan originTypes, API akan menghapus data dari asal web yang tidak dilindungi secara default.
  • protectedWeb mencakup asal web yang telah diinstal sebagai aplikasi yang dihosting. Misalnya, menginstal Angry Birds akan melindungi origin https://chrome.angrybirds.com, dan menghapusnya dari kategori unprotectedWeb. Berhati-hatilah saat memicu penghapusan data untuk asal ini: pastikan pengguna Anda mengetahui apa yang mereka dapatkan, karena tindakan ini akan menghapus data game mereka secara permanen. Tidak ada yang ingin merobohkan rumah babi kecil lebih sering dari yang diperlukan.
  • extension mencakup origin dalam skema chrome-extensions:. Menghapus data ekstensi adalah sesuatu yang harus Anda lakukan dengan sangat hati-hati.

Kita dapat menyesuaikan contoh sebelumnya untuk menghapus hanya data dari situs yang dilindungi sebagai berikut:

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); 

Contoh

Untuk mencoba API ini, instal contoh browsingData API dari repositori chrome-extension-samples.

Jenis

DataTypeSet

Kumpulan jenis data. Jenis data yang tidak ada diinterpretasikan sebagai false.

Properti

  • appcache

    boolean opsional

    Appcache situs.

  • cache

    boolean opsional

    Cache browser.

  • cacheStorage

    boolean opsional

    Chrome 72+

    Penyimpanan cache

  • cookie

    boolean opsional

    Cookie browser.

  • download

    boolean opsional

    Daftar download browser.

  • fileSystems

    boolean opsional

    Sistem file situs.

  • formData

    boolean opsional

    Data formulir yang disimpan browser.

  • sejarah

    boolean opsional

    Histori browser.

  • indexedDB

    boolean opsional

    Data IndexedDB situs.

  • localStorage

    boolean opsional

    Data penyimpanan lokal situs.

  • sandi

    boolean opsional

    Sandi tersimpan.

  • pluginData

    boolean opsional

    Tidak digunakan lagi sejak Chrome 88

    Dukungan untuk Flash telah dihapus. Jenis data ini akan diabaikan.

    Data plugin.

  • serverBoundCertificates

    boolean opsional

    Tidak digunakan lagi sejak Chrome 76

    Dukungan untuk sertifikat terikat server telah dihapus. Jenis data ini akan diabaikan.

    Sertifikat terikat server.

  • serviceWorkers

    boolean opsional

    Service Worker.

  • webSQL

    boolean opsional

    Data WebSQL situs.

RemovalOptions

Opsi yang menentukan secara tepat data yang akan dihapus.

Properti

  • excludeOrigins

    string[] opsional

    Chrome 74+

    Jika ada, data untuk origin dalam daftar ini tidak akan dihapus. Tidak dapat digunakan bersama dengan origins. Hanya didukung untuk cookie, penyimpanan, dan cache. Cookie dikecualikan untuk seluruh domain yang dapat didaftarkan.

  • originTypes

    objek opsional

    Objek yang propertinya menentukan jenis asal yang harus dihapus. Jika objek ini tidak ditentukan, defaultnya adalah menghapus hanya asal "tidak terlindungi". Pastikan Anda benar-benar ingin menghapus data aplikasi sebelum menambahkan 'protectedWeb' atau 'extensions'.

    • Pemeriksaan Keselamatan

      boolean opsional

      Ekstensi dan aplikasi paket yang telah diinstal pengguna (berhati-hatilah _sungguh-sungguh_!).

    • protectedWeb

      boolean opsional

      Situs yang telah diinstal sebagai aplikasi yang dihosting (berhati-hatilah!).

    • unprotectedWeb

      boolean opsional

      Situs normal.

  • asal

    [string, ...string[]] opsional

    Chrome 74+

    Jika ada, hanya data untuk asal di daftar ini yang dihapus. Hanya didukung untuk cookie, penyimpanan, dan cache. Cookie dihapus untuk seluruh domain yang dapat didaftarkan.

  • sejak

    nomor opsional

    Menghapus data yang dikumpulkan pada atau setelah tanggal ini, yang ditampilkan dalam milidetik sejak epoch (dapat diakses melalui metode getTime objek JavaScript Date). Jika tidak ada, nilai defaultnya adalah 0 (yang akan menghapus semua data penjelajahan).

Metode

remove()

chrome.browsingData.remove(
  options: RemovalOptions,
  dataToRemove: DataTypeSet,
)
: Promise<void>

Menghapus berbagai jenis data penjelajahan yang disimpan di profil pengguna.

Parameter

Hasil

  • Promise<void>

    Chrome 96+

removeAppcache()

chrome.browsingData.removeAppcache(
  options: RemovalOptions,
)
: Promise<void>

Menghapus data appcache situs.

Parameter

Hasil

  • Promise<void>

    Chrome 96+

removeCache()

chrome.browsingData.removeCache(
  options: RemovalOptions,
)
: Promise<void>

Menghapus cache browser.

Parameter

Hasil

  • Promise<void>

    Chrome 96+

removeCacheStorage()

Chrome 72+
chrome.browsingData.removeCacheStorage(
  options: RemovalOptions,
)
: Promise<void>

Menghapus data penyimpanan cache situs.

Parameter

Hasil

  • Promise<void>

    Chrome 96+

removeCookies()

chrome.browsingData.removeCookies(
  options: RemovalOptions,
)
: Promise<void>

Menghapus cookie browser dan sertifikat terikat server yang diubah dalam jangka waktu tertentu.

Parameter

Hasil

  • Promise<void>

    Chrome 96+

removeDownloads()

chrome.browsingData.removeDownloads(
  options: RemovalOptions,
)
: Promise<void>

Menghapus daftar file yang didownload di browser (bukan file yang didownload itu sendiri).

Parameter

Hasil

  • Promise<void>

    Chrome 96+

removeFileSystems()

chrome.browsingData.removeFileSystems(
  options: RemovalOptions,
)
: Promise<void>

Menghapus data sistem file situs.

Parameter

Hasil

  • Promise<void>

    Chrome 96+

removeFormData()

chrome.browsingData.removeFormData(
  options: RemovalOptions,
)
: Promise<void>

Menghapus data formulir tersimpan (isi otomatis) browser.

Parameter

Hasil

  • Promise<void>

    Chrome 96+

removeHistory()

chrome.browsingData.removeHistory(
  options: RemovalOptions,
)
: Promise<void>

Menghapus histori browser.

Parameter

Hasil

  • Promise<void>

    Chrome 96+

removeIndexedDB()

chrome.browsingData.removeIndexedDB(
  options: RemovalOptions,
)
: Promise<void>

Menghapus data IndexedDB situs.

Parameter

Hasil

  • Promise<void>

    Chrome 96+

removeLocalStorage()

chrome.browsingData.removeLocalStorage(
  options: RemovalOptions,
)
: Promise<void>

Menghapus data penyimpanan lokal situs.

Parameter

Hasil

  • Promise<void>

    Chrome 96+

removePasswords()

chrome.browsingData.removePasswords(
  options: RemovalOptions,
)
: Promise<void>

Menghapus sandi tersimpan browser.

Parameter

Hasil

  • Promise<void>

    Chrome 96+

removePluginData()

Tidak digunakan lagi sejak Chrome 88
chrome.browsingData.removePluginData(
  options: RemovalOptions,
)
: Promise<void>

Dukungan untuk Flash telah dihapus. Fungsi ini tidak berpengaruh.

Menghapus data plugin.

Parameter

Hasil

  • Promise<void>

    Chrome 96+

removeServiceWorkers()

Chrome 72+
chrome.browsingData.removeServiceWorkers(
  options: RemovalOptions,
)
: Promise<void>

Menghapus pekerja layanan situs.

Parameter

Hasil

  • Promise<void>

    Chrome 96+

removeWebSQL()

chrome.browsingData.removeWebSQL(
  options: RemovalOptions,
)
: Promise<void>

Menghapus data WebSQL situs.

Parameter

Hasil

  • Promise<void>

    Chrome 96+

settings()

chrome.browsingData.settings(): Promise<object>

Melaporkan jenis data yang saat ini dipilih di UI setelan 'Hapus data penjelajahan'. Catatan: beberapa jenis data yang disertakan dalam API ini tidak tersedia di UI setelan, dan beberapa setelan UI mengontrol lebih dari satu jenis data yang tercantum di sini.

Hasil

  • Promise<object>

    Chrome 96+