HTML5 - Penyimpanan Web
HTML5 memperkenalkan dua mekanisme, mirip dengan cookie sesi HTTP, untuk menyimpan data terstruktur di sisi klien dan untuk mengatasi kekurangan berikut.
Cookies disertakan dengan setiap permintaan HTTP, sehingga memperlambat aplikasi web Anda dengan mengirimkan data yang sama.
Cookie disertakan dengan setiap permintaan HTTP, sehingga mengirimkan data yang tidak terenkripsi melalui internet.
Cookie dibatasi hingga sekitar 4 KB data. Tidak cukup untuk menyimpan data yang dibutuhkan.
Kedua penyimpanan tersebut session storage dan local storage dan mereka akan digunakan untuk menangani situasi yang berbeda.
Versi terbaru dari hampir semua browser mendukung Penyimpanan HTML5 termasuk Internet Explorer.
Penyimpanan Sesi
The Sesi Storage dirancang untuk skenario di mana pengguna melakukan satu transaksi, tapi bisa melakukan beberapa transaksi dalam jendela yang berbeda pada waktu yang sama.
Contoh
Misalnya, jika pengguna membeli tiket pesawat di dua jendela berbeda, menggunakan situs yang sama. Jika situs menggunakan cookie untuk melacak tiket mana yang dibeli pengguna, maka saat pengguna mengklik dari halaman ke halaman di kedua jendela, tiket yang saat ini dibeli akan "bocor" dari satu jendela ke jendela lainnya, berpotensi menyebabkan pengguna untuk beli dua tiket untuk penerbangan yang sama tanpa benar-benar menyadarinya.
HTML5 memperkenalkan atribut sessionStorage yang akan digunakan oleh situs untuk menambahkan data ke penyimpanan sesi, dan itu akan dapat diakses ke halaman manapun dari situs yang sama yang dibuka di jendela itu, yaitu,session dan segera setelah Anda menutup jendela, sesi tersebut akan hilang.
Berikut adalah kode yang akan mengatur variabel sesi dan mengakses variabel itu -
<!DOCTYPE HTML>
<html>
<body>
<script type = "text/javascript">
if( sessionStorage.hits ) {
sessionStorage.hits = Number(sessionStorage.hits) +1;
} else {
sessionStorage.hits = 1;
}
document.write("Total Hits :" + sessionStorage.hits );
</script>
<p>Refresh the page to increase number of hits.</p>
<p>Close the window and open it again and check the result.</p>
</body>
</html>
Ini akan menghasilkan hasil sebagai berikut -
Penyimpanan lokal
The Storage Lokal dirancang untuk penyimpanan yang bentang beberapa jendela, dan berlangsung di luar sesi saat ini. Secara khusus, aplikasi Web mungkin ingin menyimpan megabyte data pengguna, seperti seluruh dokumen yang ditulis pengguna atau kotak surat pengguna, di sisi klien untuk alasan kinerja.
Sekali lagi, cookie tidak menangani kasus ini dengan baik, karena dikirimkan bersama setiap permintaan.
Contoh
HTML5 memperkenalkan atribut localStorage yang akan digunakan untuk mengakses area penyimpanan lokal halaman tanpa batas waktu dan penyimpanan lokal ini akan tersedia setiap kali Anda akan menggunakan halaman itu.
Berikut adalah kode yang akan menetapkan variabel penyimpanan lokal dan mengakses variabel itu setiap kali halaman ini diakses, bahkan di lain waktu, ketika Anda membuka jendela -
<!DOCTYPE HTML>
<html>
<body>
<script type = "text/javascript">
if( localStorage.hits ) {
localStorage.hits = Number(localStorage.hits) +1;
} else {
localStorage.hits = 1;
}
document.write("Total Hits :" + localStorage.hits );
</script>
<p>Refresh the page to increase number of hits.</p>
<p>Close the window and open it again and check the result.</p>
</body>
</html>
Ini akan menghasilkan hasil sebagai berikut -
Hapus Penyimpanan Web
Menyimpan data sensitif di komputer lokal bisa berbahaya dan bisa meninggalkan celah keamanan.
The Sesi Penyimpanan Data akan dihapus oleh browser segera setelah sesi akan berakhir.
Untuk menghapus pengaturan penyimpanan lokal, Anda perlu menelepon localStorage.remove('key'); di mana 'key' adalah kunci dari nilai yang ingin Anda hapus. Jika Anda ingin menghapus semua pengaturan, Anda perlu meneleponlocalStorage.clear() metode.
Berikut adalah kode yang akan menghapus penyimpanan lokal lengkap -
<!DOCTYPE HTML>
<html>
<body>
<script type = "text/javascript">
localStorage.clear();
// Reset number of hits.
if( localStorage.hits ) {
localStorage.hits = Number(localStorage.hits) +1;
} else {
localStorage.hits = 1;
}
document.write("Total Hits :" + localStorage.hits );
</script>
<p>Refreshing the page would not to increase hit counter.</p>
<p>Close the window and open it again and check the result.</p>
</body>
</html>
Ini akan menghasilkan hasil sebagai berikut -