サーブレットを使用してセッションを制御する セッション状態の維持は、Web アプリケーションの開発時に直面する必要がある問題です。この問題を解決するには、さまざまな方法があります。たとえば、Cookie を使用したり、非表示タイプのフォーム フィールドを使用したり、URL にステータス情報を直接追加したりするなど、サーブレット自体がセッション状態の維持をサポートする HttpSession インターフェイスを提供します。ここでは、主にセッション状態ベースの管理について紹介します。このインターフェース上で。 セッションは、HTTP プロトコルの制限を満たすために発明されました。 HTTP プロトコルの仕組みに注意してください - ユーザーがリクエストを行い、サーバーが応答します。クライアントとサーバー間のこの接続は個別かつ不連続です。 HTTP プロトコルには、サーバーがユーザーのリクエストを追跡できる機能はありません。サーバーがユーザーのリクエストへの応答を完了すると、サーバーはブラウザーとの接続を維持し続けることができなくなります。サーバー側から見ると、各リクエストは独立しているため、HTTP プロトコルはステートレス プロトコルとみなされ、ユーザーが複数のホームページ間を切り替えても、サーバーはユーザーの身元を知ることができません。 Session の登場は、この制限を補うものです。セッションを使用すると、ユーザーが複数のホームページを切り替えたときにその情報を保存できます。これにより、以前は不可能だった多くのことがはるかに簡単になります。 訪問者が特定のホームページに到着してから離れるまでの期間、各訪問者は個別のセッションを受け取ります。 を使用することもできます。(2) セッション変数を書き込みます。 HttpSession.setAttribute(name, value) メソッドを使用して、セッションに情報を保存できます。 HttpSession.putValue(name, value) を使用することもできますが、このメソッドは廃止されました。 (3) セッション変数を読み込みます。 HttpSession.getAttribute(name) メソッドを使用して、セッション内の変数の値を読み取ることができます。name が未定義の変数の場合は、null が返されます。 getAttribute から読み取られる変数の型は Object であるため、次のような強制的な型変換を使用する必要があることに注意してください。 (4) セッションを閉じる セッションを使用した後、session.invalidate() メソッドを使用してセッションを閉じることができます。しかし、これは厳密には必須ではありません。サーブレット エンジンは一定時間が経過するとセッションを自動的に閉じるためです。 以下は、session の使用法を示す簡単な例です。 Out.println(""); //セッションオブジェクトが最後にアクセスされた時刻を取得します session.setattribute ("uID", "12345678");
|
以上がJAVA はサーブレットを介して JSP のセッション変数をどのように操作しますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。