如何在CMS PHP

时间:2015-05-29 10:06:55

标签: php mysql login content-management-system logout

我正在尝试从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());
}
?>

1 个答案:

答案 0 :(得分:0)

请参阅我的回答:Logout an inactive user using PHP

根据您当前的代码,问题是您的查询 $scope.range = function(n){ var array = []; for(var i = 0 ; i < n ; i++) array.push(i); return array; }; $scope.images = ['1.gif', '2.gif', '3.gif', '4.gif', 'any.gif']; $scope.msg = { 'images': [] }; $scope.updateImages = function() { // alert($scope.numOfImages); $scope.msg.images.splice($scope.numOfImages, $scope.msg.images.length); } 超出函数 logoutInactiveUser(),因此变量 $ timeout 将不包含数据库中的任何数据。移动函数内部的代码应该可以帮到你。