ホームページ >バックエンド開発 >PHPチュートリアル >2 つのハンドラーから PHP のセッション メカニズムを見てみる_PHP チュートリアル
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 には、多くのメソッドがあります:
session.save_handler = ユーザー
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 を実行します
実際的な例:
れーれー