ホームページ ウェブフロントエンド jsチュートリアル Cookie、ローカル ストレージ、セッション ストレージ

Cookie、ローカル ストレージ、セッション ストレージ

Jan 05, 2025 pm 07:53 PM

Cookies, Local storage and Session storage

これは、フロントエンドのインタビューの質問シリーズの投稿 #6 です。準備をレベルアップしたい場合、または常に最新情報を入手したい場合は、Frontend Camp へのサインアップを検討してください。


Cookie、ローカル ストレージ、およびセッション ストレージはすべて、クライアント側でデータを保存するために使用されます。これらのメカニズムは、認証トークンや、テーマや個人設定などのクライアントのみの状態を保存する場合に特に役立ちます。 3 つのストレージ タイプはすべて、次の特性を共有しています:

  1. データはキーと値のペアとして保存されます。
  2. すべての値は文字列形式で保存されます。値が文字列でない場合は、保存される前にシリアル化されます。
  3. これらのメカニズムに保存されたデータは、クライアントからアクセスできます (HttpOnly Cookie を除く)。

クッキー

Cookie は大量のデータを保存できません。ストレージの上限はドメインごとに約 4KB です。この制限が存在するのは、ブラウザによってリクエストが行われるたびに Cookie が自動的にサーバーに送信されるためです。過剰なクライアント側データを Cookie に保存すると、ペイロード サイズが増加し、パフォーマンスに悪影響を及ぼします。

Cookie にはどのようなデータを保存する必要がありますか?
Cookie は、認証トークン、セッション ID、分析 ID、および同様の情報など、サーバーに送信する必要があるデータを保存するのに最適です。さらに、Cookie を使用すると、同じドメインまたはサブドメインの異なるタブまたはウィンドウ間でデータを共有できます。

さまざまなフラグを使用して Cookie を構成し、動作を調整したり、セキュリティを強化したりできます。

  • HttpOnly は、クライアント側の JavaScript 経由で Cookie にアクセスできないようにし、XSS 攻撃のリスクを軽減します。
  • maxAge/expires は、Cookie の有効期限を指定します。有効期限が設定されていない場合、Cookie はブラウザを閉じると削除されます。

Cookie フラグについて詳しく知りたいですか?私の LinkedIn 投稿をチェックしてください。

ローカル ストレージやセッション ストレージとは異なり、Cookie は Set-Cookie ヘッダーを使用してサーバーによって設定 (「追加」と読みます) することもできます。

// Set a cookie for the key `token` that `expires` on 1st March 2025.
document.cookie =
  'token=a1-b2-c3; expires=Sat, 1 Mar 2025 23:59:59 GMT; path=/';

// Read all cookies. There's no way to read specific cookies using `document.cookie`.
// You have to parse the string yourself.
console.log(document.cookie); // token=a1-b2-c3

// Delete the cookie with the key `token` by setting an
// expiry date in the past. The value doesn't matter.
document.cookie = 'token=; expires=Thu, 01 Jan 1970 00:00:00 GMT; path=/';
ログイン後にコピー
ログイン後にコピー

ローカルストレージ

Cookie とは異なり、localStorage はドメインごとに約 5MB という大幅に大きなストレージ容量を提供します。これは、localStorage が長期データを保存するように設計されているためです。ブラウザが閉じているときでもデータが保持されるため、クライアント側の永続的なストレージのニーズに最適です。

では、localStorage にはどのようなデータを保存すればよいでしょうか?
localStorage は、クライアント側でのみ使用され、リクエストごとにサーバーに送信する必要のないデータの保存に最適です。例としては、Web サイトのテーマや、ユーザーがサインインする前にカートに追加された製品などがあります。

localStorage に保存されたデータは、ユーザーが手動で削除するか、Web サイトが JavaScript を使用してデータを消去するまで無期限に保持されます。

Cookie と同様に、localStorage 内のデータは、同じ生成元のすべてのタブまたはウィンドウからアクセスできるため、ドメイン内のクライアント側の状態を共有するのに役立ちます。

// Set a cookie for the key `token` that `expires` on 1st March 2025.
document.cookie =
  'token=a1-b2-c3; expires=Sat, 1 Mar 2025 23:59:59 GMT; path=/';

// Read all cookies. There's no way to read specific cookies using `document.cookie`.
// You have to parse the string yourself.
console.log(document.cookie); // token=a1-b2-c3

// Delete the cookie with the key `token` by setting an
// expiry date in the past. The value doesn't matter.
document.cookie = 'token=; expires=Thu, 01 Jan 1970 00:00:00 GMT; path=/';
ログイン後にコピー
ログイン後にコピー

セッションストレージ

sessionStorage は、有効期間の短いクライアント側データを保存するために使用されます。 localStorage と同様に、ドメインごとに約 5MB のストレージ容量を提供し、同じ API を共有します。

sessionStorage と localStorage はどちらも同様の機能を共有していますが、データ永続性アクセシビリティという 2 つの重要な側面が異なります。
localStorage とは異なり、sessionStorage はタブまたはブラウザを閉じるとデータを保持しません。さらに、sessionStorage に保存されたデータは、そのデータが作成された特定のタブまたはウィンドウに分離されます。つまり、同じオリジンの他のタブまたはウィンドウはアクセスできません。

sessionStorage の使用例は何ですか?
sessionStorage は、単一セッションにのみ必要なデータを保存するのに最適です。たとえば、ユーザーが長いフォームに入力し、誤ってページを更新したとします。フォーム データが sessionStorage に保存されている場合、それは更新中も保持されるため、ユーザーは進行状況を失うことなく続行できます。

ただし、このデータは別のタブからアクセスしたり、タブを閉じるとアクセスできなくなることに注意してください。

// Set a value in localStorage.
localStorage.setItem('theme', 'dark');

// Get a value from localStorage.
console.log(localStorage.getItem('theme')); // 'dark'

// Remove a value from localStorage.
localStorage.removeItem('theme');

// Clear all data in localStorage.
localStorage.clear();
ログイン後にコピー

Cookie はブラウザーによって送信されるすべてのリクエストに自動的に含まれますが、localStorage または sessionStorage に保存されているデータは、カスタム コードを記述することでサーバーに手動で送信できます。


まとめ

  1. Cookie、localStorage、sessionStorage は、クライアント側にデータを保存するために使用されます。
  2. Cookie は、Set-Cookie 応答ヘッダーを使用してサーバーによって設定できる唯一のストレージ形式です。
  3. Cookie はリクエストごとに自動的にサーバーに送信されます。
  4. localStorage と sessionStorage は、Cookie (4KB) に比べて非常に大きなストレージ (5MB) を持っています。これらのストレージはどちらも同じ API インターフェイスを共有します。
  5. Cookie には有効期限があり、有効期限がない場合はブラウザを閉じると消去されます。
  6. localStorage データは、ユーザーまたは Web サイト自体が手動で消去しない限り、無期限に存続します。
  7. sessionStorage データは、セッションの終了後、つまりタブまたはウィンドウが閉じられたときにクリアされます。

今読んだ内容は気に入りましたか?フロントエンド キャンプをチェックしてみてください ✌️

以上がCookie、ローカル ストレージ、セッション ストレージの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Python vs. JavaScript:学習曲線と使いやすさ Python vs. JavaScript:学習曲線と使いやすさ Apr 16, 2025 am 12:12 AM

Pythonは、スムーズな学習曲線と簡潔な構文を備えた初心者により適しています。 JavaScriptは、急な学習曲線と柔軟な構文を備えたフロントエンド開発に適しています。 1。Python構文は直感的で、データサイエンスやバックエンド開発に適しています。 2。JavaScriptは柔軟で、フロントエンドおよびサーバー側のプログラミングで広く使用されています。

JavaScriptとWeb:コア機能とユースケース JavaScriptとWeb:コア機能とユースケース Apr 18, 2025 am 12:19 AM

Web開発におけるJavaScriptの主な用途には、クライアントの相互作用、フォーム検証、非同期通信が含まれます。 1)DOM操作による動的なコンテンツの更新とユーザーインタラクション。 2)ユーザーエクスペリエンスを改善するためにデータを提出する前に、クライアントの検証が実行されます。 3)サーバーとのリフレッシュレス通信は、AJAXテクノロジーを通じて達成されます。

JavaScript in Action:実際の例とプロジェクト JavaScript in Action:実際の例とプロジェクト Apr 19, 2025 am 12:13 AM

現実世界でのJavaScriptのアプリケーションには、フロントエンドとバックエンドの開発が含まれます。 1)DOM操作とイベント処理を含むTODOリストアプリケーションを構築して、フロントエンドアプリケーションを表示します。 2)node.jsを介してRestfulapiを構築し、バックエンドアプリケーションをデモンストレーションします。

JavaScriptエンジンの理解:実装の詳細 JavaScriptエンジンの理解:実装の詳細 Apr 17, 2025 am 12:05 AM

JavaScriptエンジンが内部的にどのように機能するかを理解することは、開発者にとってより効率的なコードの作成とパフォーマンスのボトルネックと最適化戦略の理解に役立つためです。 1)エンジンのワークフローには、3つの段階が含まれます。解析、コンパイル、実行。 2)実行プロセス中、エンジンはインラインキャッシュや非表示クラスなどの動的最適化を実行します。 3)ベストプラクティスには、グローバル変数の避け、ループの最適化、constとletsの使用、閉鎖の過度の使用の回避が含まれます。

Python vs. JavaScript:コミュニティ、ライブラリ、リソース Python vs. JavaScript:コミュニティ、ライブラリ、リソース Apr 15, 2025 am 12:16 AM

PythonとJavaScriptには、コミュニティ、ライブラリ、リソースの観点から、独自の利点と短所があります。 1)Pythonコミュニティはフレンドリーで初心者に適していますが、フロントエンドの開発リソースはJavaScriptほど豊富ではありません。 2)Pythonはデータサイエンスおよび機械学習ライブラリで強力ですが、JavaScriptはフロントエンド開発ライブラリとフレームワークで優れています。 3)どちらも豊富な学習リソースを持っていますが、Pythonは公式文書から始めるのに適していますが、JavaScriptはMDNWebDocsにより優れています。選択は、プロジェクトのニーズと個人的な関心に基づいている必要があります。

Python vs. JavaScript:開発環境とツール Python vs. JavaScript:開発環境とツール Apr 26, 2025 am 12:09 AM

開発環境におけるPythonとJavaScriptの両方の選択が重要です。 1)Pythonの開発環境には、Pycharm、Jupyternotebook、Anacondaが含まれます。これらは、データサイエンスと迅速なプロトタイピングに適しています。 2)JavaScriptの開発環境には、フロントエンドおよびバックエンド開発に適したnode.js、vscode、およびwebpackが含まれます。プロジェクトのニーズに応じて適切なツールを選択すると、開発効率とプロジェクトの成功率が向上する可能性があります。

JavaScript通訳者とコンパイラにおけるC/Cの役割 JavaScript通訳者とコンパイラにおけるC/Cの役割 Apr 20, 2025 am 12:01 AM

CとCは、主に通訳者とJITコンパイラを実装するために使用されるJavaScriptエンジンで重要な役割を果たします。 1)cは、JavaScriptソースコードを解析し、抽象的な構文ツリーを生成するために使用されます。 2)Cは、Bytecodeの生成と実行を担当します。 3)Cは、JITコンパイラを実装し、実行時にホットスポットコードを最適化およびコンパイルし、JavaScriptの実行効率を大幅に改善します。

Webサイトからアプリまで:JavaScriptの多様なアプリケーション Webサイトからアプリまで:JavaScriptの多様なアプリケーション Apr 22, 2025 am 12:02 AM

JavaScriptは、Webサイト、モバイルアプリケーション、デスクトップアプリケーション、サーバー側のプログラミングで広く使用されています。 1)Webサイト開発では、JavaScriptはHTMLおよびCSSと一緒にDOMを運用して、JQueryやReactなどのフレームワークをサポートします。 2)ReactNativeおよびIonicを通じて、JavaScriptはクロスプラットフォームモバイルアプリケーションを開発するために使用されます。 3)電子フレームワークにより、JavaScriptはデスクトップアプリケーションを構築できます。 4)node.jsを使用すると、JavaScriptがサーバー側で実行され、高い並行リクエストをサポートします。

See all articles