session_start()

セッション

概要

 状態:-  閲覧数:1,665  投稿日:2017-02-09  更新日:2017-02-24  
セッションの open ハンドラおよび read ハンドラをコール
・デフォルトで組み込まれている保存ハンドラの他に PHP 拡張モジュールで提供されているもの (SQLite や Memcached など) も使用可能
・また、自作のハンドラを session_set_save_handler() で定義することも可能
・read コールバックは既存のセッションデータ (独自のシリアライズフォーマットで保存されているもの) を読み込み、 それを復元して自動的にスーパーグローバル $_SESSION へ格納

特徴

 閲覧数:463 投稿日:2017-02-24 更新日:2017-02-24 

リクエスト毎に実行


リクエスト毎にsession_start()自体を毎回呼び出す必要がある
・リクエスト時点で$_SESSIONは‌常に​空


二重実行不可


セッションが既に開始されている状態で session_start() をコールすると?
・E_NOTICE レベルのエラー発生
・その場合二度目のセッションスタートは無視される
Notice: A session had already been started - ignoring session_start()


まとめると?


リクエスト毎にsession_start()を実行する必要があるが、二重に実行することは出来ない
→ E_NOTICE エラー発生

セッションが既に開始されている状態か確認が必要

セッションが既に開始されている場合
・$_SESSIONに変数がセットされている
・NULL でない
if(!isset($_SESSION)){
 session_start();
}


セッション期限

 閲覧数:481 投稿日:2017-02-24 更新日:2017-02-24 

セッション期限は延長しない


セッションの有効期限
・session_start()を呼び出すときにsession.cache_expireで指定した単位で常に更新される

デフォルトセッション有効期限
・24分間

23分経過後にアクセス
・セッション残り時間は1分
session_start();
・その時点から24分間有効

有効期限は延長しない
・24分間が、30分間に延長されるわけでない



有効期限後にアクセス


25分経過後にアクセス
・セッションは既に切れている
・$_SESSIONは空
・session_start()で再開
if(!isset($_SESSION)){
 session_start();
}

セッションが切れたセッションファイルへアクセスすると、セッションは再開される
・その時点から再び24分間セッション継続
・ユーザにとっては、セッション継続しているように見える
・これをセッションの有効期限延長と呼ぶ


具体例


PHPでセッションスタートしたら、セッションが切れるまでセッション期間は延長出来ない
・セッション期間を5分と設定
・10時にアクセスしてセッション開始
※この時点では10時5分までセッション有効

・10時3分にアクセス
・$_SESSIONは存在していないため、session_start実行
if(!isset($_SESSION)){
session_start();
}

Q.この時、セッション有効期限は延長されるのでしょうか?
・10時8分まで延長される
・延長というよりは、この時点から再度5分間有効になる
PHPでセッションスタートしたら、セッションが切れるまでセッション期間は


PHP
セッションが既に開始されている状態で session_start() をコールすると E_NOTICE レベルのエラーを発生させます。 またその場合二度目のセッションスタートは単に無視されます


・session_start()する度毎に、session_set_save_handler()引数で指定したSessionHandlerInterfaceを継承したクラスを呼出
・session_start()する度毎に、readメソッド呼出

session_start() する度に毎回呼出されるreadメソッド内で、$GLOBALSへは格納できるが、$_SESSIONへは格納できない
・恐らくsession_set_save_handler()のメソッド内では、$_SESSION内容の変更は出来ないものと思われ
・session_start()→session_set_save_handler()→ この時点で初めて操作可能?
 public function read($id)
   {
       echo "------_read-----<pre>";
       var_dump(date("H:i:s",time()));
       echo "</pre>";
       $_SESSION['last_updated'] = time();
       
          $GLOBALS['b'] = time();






「有効期限内にセッションに再アクセスがあった場合は、期間は延長される」のセッションとは?
session_set_save_handlerが呼ばれるタイミングで通常のセッション処理を行う場合は、SessionHandlerInterface を呼び出せば良い?
session fingerprint とはどんな概念なのでしょうか?「セッションID」を不正取得された場合のセキュリティ対策?
セッションハイジャックを防ぐ7つの方法
PHPプロ!TIPS+


session_save_path()

session.gc_maxlifetime

コメント投稿(ログインが必要)



類似度ページランキング
順位 ページタイトル抜粋
1 session_start() 73
2 session_save_path() 59
3 Generators 56
4 session_set_save_handler() 54
5 Doctrine 52
6 ob_start 52
7 parse_url( ) 52
8 syntax error 52
9 register_globals 52
10 set_error_handler 50
11 session_destroy関数 50
12 include_path 44
13 array_filter 44
14 session.hash_function 44
15 session.gc_maxlifetime 43
16 SessionHandler::gc 42
17 isset 40
18 var_dump() 40
19 die() 40
20 SHA-1(Secure Hash Algorithm 1) 40
2025/2/06 9:53 更新
週間人気ページランキング / 1-30 → 2-5
順位 ページタイトル抜粋 アクセス数
1 Parse error: syntax error, unexpected 'public' (T_PUBLIC) | Parse error(エラーメッセージ) 10
2 ブラウザを閉じたらセッションデータはどうなるの? | セッション 9
3 curl で Cookie を使用する 4
3 Fatal error: Access level to ▲::$△ must be protected (as in class ●) or weaker | Fatal error(エラーメッセージ) 4
3 PHPで定数を定義する方法は2種類ある / 配列定数の定義 4
4 コード例 … 「例外処理」はネストすることができる 3
4 Warning: PDO::query(): LOAD DATA LOCAL INFILE forbidden | Warning(エラーメッセージ) 3
4 http_build_queryとは? / 構文 /パラメータ 3
4 Mailer Error: SMTP connect() failed. https://github.com/PHPMailer/PHPMailer/wiki/Troubleshooting | エラーメッセージ 3
5 Fatal error: Cannot redeclare 関数名() (previously declared in ファイル名:○○) in ファイル名 | Fatal error(エラーメッセージ) 2
5 Fatal error: Uncaught exception 'PDOException' with message 'SQLSTATE[28000] [1045] Access denied for user 'データベースユーザー名'@'localhost' (using password: YES)' | phpMyAdmin(データベース関連) 2
5 ( ! ) Fatal error: Uncaught PDOException: SQLSTATE[HY093]: Invalid parameter number: parameter was not defined | Fatal error(エラーメッセージ) 2
5 new clone違い | 演算子 2
5 オブジェクト関係マッピング | データベース関連 2
5 array_filter | 配列 2
6 Fatal error: Uncaught Error: Call to a member function modify() on string | Fatal error(エラーメッセージ) 1
6 Fatal error: require_once(): Failed opening required 'PEAR.php' | Fatal error(エラーメッセージ) 1
6 セッション単位 | セッション 1
6 htmlspecialchars / htmlentities / addslashes / mysql_real_escape_string / mysqli_real_escape_string | セキュリティ 1
6 dirname() / (__FILE__ ) / basename( dirname( __FILE__ ) ); | 関数 1
2025/2/6 1:02 更新