我试图从我的CMS强制注销一个不活跃的用户。超时值存储在数据库中名为PREF_TIMEOUT的值中。我借用了这段代码并稍微修改了一下。代码似乎没有做任何事情。有没有人知道一个更好的方法来做这件事,或者能发现是什么破坏了它?
<?php
function init() {
parent:: init();
self::logoutInactiveUser();
}
$timeout = mysql_query("SELECT PREF_TIMEOUT FROM preferences WHERE PREF_ID = '1'");
$result = mysql_fetch_array($timeout);
function logoutInactiveUser() {
$inactivityLimit = $timeout * 60; // Converted to seconds
$sessionStart = Session::get('session_start_time');
if (isset($sessionStart)){
$elapsed_time = time() - Session::get('session_start_time');
if ($elapsed_time >= $inactivityLimit) {
$member = Member::currentUser();
if($member) $member->logOut();
Session::clear_all();
Director::redirect(Director::baseURL() . 'Security/login');
}
}
Session::set('session_start_time', time());
}
?>
请参阅链接中的答案:使用PHP注销非活动用户。
根据您当前的代码,问题是您的查询
$timeout = mysql_query("SELECT PREF_TIMEOUT FROM preferences WHERE PREF_ID = '1'");
$result = mysql_fetch_array($timeout);
在函数logoutInactiveUser()之外,因此变量$timeout将没有来自数据库的任何数据。将代码移到函数内部应该会有所帮助。