ホームページ >バックエンド開発 >PHPチュートリアル >2 つのハンドラーから PHP のセッション メカニズムを見てみる_PHP チュートリアル

2 つのハンドラーから PHP のセッション メカニズムを見てみる_PHP チュートリアル

WBOY
WBOYオリジナル
2016-07-13 10:33:18841ブラウズ

session.save_handler = ファイル

1. session_start()

session_start() はセッションメカニズムの始まりであり、セッションはファイルに保存されるため、SESSION リサイクルは無効になります。この確率はファイルの削除に基づいています。これは ini の設定によって決まりますが、一部のシステムでは session.gc_probability = 0 (確率が 0 であることを意味し、ガベージ コレクションは cron スクリプトを通じて実装されます) になっています。

リーリー

session は現在 $_COOKIE[session_name()] が存在するかどうかを判断します; session_name() は session_id を保存する COOKIE キーの値を返します。この値は php.ini session.name = PHPSESSID //デフォルト値 PHPSESSID から確認できます。

存在しない場合は、session_id が生成され、生成された session_id が COOKIE の値としてクライアントに渡されます。これは、次の COOKIE 操作を実行するのと同じです。このステップは setcookie() 操作を実行します。ヘッダーに COOKIE が含まれている場合、PHP には別の関数 session_regenerate_id() があり、この関数を使用すると、これより前に出力がありません。

リーリー

存在する場合は、 session_id = $_COOKIE[session_name]; 次に、 session.save_path で指定されたフォルダーに移動して、 'SESS_' という名前のファイルを見つけます。ファイルの内容を読み取り、デシリアライズして、$_SESSION に配置します。

2. $_SESSION に値を代入します

たとえば、新しい値 $_SESSION['test'] = 'blah'; を追加すると、この $_SESSION はメモリ内にのみ保持され、スクリプトの実行が終了すると、$_SESSION の値が指定されたフォルダーに書き込まれます。 session_id を入力し、関連するリソースを閉じます。

この段階では、古い session_id を破棄して新しい session_id を生成するなど、session_id を変更する操作を実行できます。Drupal 匿名ユーザーなどのカスタム セッション操作とロール変換に使用されます。 SESSION。ログインするときは、新しい session_id を使用する必要があります。

リーリー

3. セッションの書き込み操作

スクリプトの最後で、SESSION 書き込み操作が実行され、$_SESSION の値が session_id で指定されたファイルに書き込まれます。このファイルは既に存在する場合があり、新しいファイルを作成する必要がある場合があります。

4.セッションを破棄します

SESSION によって送信される COOKIE は通常、インスタント COOKIE であり、ブラウザを閉じると期限切れになります。ブラウザを閉じる代わりにログアウトするなど、手動で有効期限を強制する必要がある場合は、コード内の SESSION には、多くのメソッドがあります:

    setcookie(session_name(), session_id(), time() - 8000000, ..);//ログアウト前に実行
  • usset($_SESSION);//これにより、すべての $_SESSION データが削除されます。更新後、COOKIE が渡されますが、データはありません。
  • session_destroy();//この関数はより完全で、$_SESSION を削除し、セッション ファイルと session_id を削除します
ブラウザを閉じずに再度更新すると、2と3にCOOKIEが送信されますが、データが見つかりません。

session.save_handler = ユーザー

ユーザー定義のセッション処理メカニズム、より直感的な session_set_save_handler('open', 'close', 'read', 'write', 'destroy', 'gc');

session_start()、open($save_path, $session_name) を実行してセッション操作ハンドルを開きます。 session.save_handler = files の場合、$save_path は session.save_path になりますが、ユーザーがカスタマイズした場合、これら 2 つのパラメーターはどちらも使用されず、直接 TRUE が返されます。 read($id) を実行してそこからデータを読み取ります。 //このパラメータは session_id() に自動的に渡され、この値を介して操作できます。

スクリプトの実行が終了したら、write($id, $sess_data) を実行します //2 つのパラメーター、非常にシンプルです

ユーザーが session_destroy() を必要とする場合は、最初に destroy を実行し、次にステップ 2 を実行します

実際的な例:

れーれー

http://www.bkjia.com/PHPjc/752515.htmlwww.bkjia.comtru​​ehttp://www.bkjia.com/PHPjc/752515.html技術記事 session.save_handler = files 1. session_start() session_start() はセッションメカニズムの始まりであり、セッションは PHP 自身のガベージであるファイルに保存されるため、一定の確率でガベージコレクションを開始します。
声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。