到目前为止我有以下打开会话(php),
session_start() ;
foreach($_SESSION as $key => $value){
$alert .= '<br/>' . '['.$key.']='.$value ;
}
$alert .= '<br/>$_SERVER[MY_SERVER...]='.$_SERVER['MY_SERVER_GENERATED'] ;
if($_SESSION['MY_SERVER_GENERATED'] !== true ||
$_SERVER['REMOTE_ADDR'] !== $_SESSION['PREV_REMOTEADDR'] ||
$_SERVER['HTTP_USER_AGENT'] !== $_SESSION['PREV_USERAGENT']){
$alert .= 'session destroyed' ;
session_destroy() ;
}
if(isset($_SESSION['CREATED']) && (strtotime('now') - $_SESSION['CREATED']) > 300){//Delete expired sessions - seconds
$alert .= '<div class="error_box">Your session has expired!</div>' ;
$_SESSION = array() ;
}
session_regenerate_id();
$_SESSION['CREATED'] = strtotime('now') ;
$_SESSION['MY_SERVER_GENERATED'] = true ;
$_SESSION['PREV_USERAGENT'] = $_SERVER['HTTP_USER_AGENT'] ;
$_SESSION['PREV_REMOTEADDR'] = $_SERVER['REMOTE_ADDR'] ;
echo $alert ;
问题是会话每次都被破坏。 $ _SESSION只是空的。在什么时候可以运行上面的检查?
哎呀忘了说明我已经验证会话正在保存数据,但是在页面启动之前没有。因此会话被销毁,因为$ _SESSION数据全为空,因此条件评估为false。例如,$ alert不会注册为存储任何内容。
答案 0 :(得分:1)
您的代码似乎有一个问题22:
session_start() ;
if(!$_SESSION['MY_SERVER_GENERATED']){ <------- this will always be true
for a fresh session, so
session_destroy() ; <--------------------- this will always be executed
您的会话数据永远不会有机会填充。