我正在使用zend框架。我已经建立了一个简单的登录屏幕。当用户登录时,我想设置一个会话,然后在成员区域控制器的 init 函数中检查会话并授予访问权限,否则,重定向到登录屏幕。
我已经像这样设置了我的登录控制器,这将检查用户名和密码并设置会话:
if (isset($_POST['loginSubmit']) && $form->isValid($_POST)){
$inputtedUsername = $_POST['username'];
$inputtedPassword = $_POST['password'];
if ($inputtedUsername == $username && $inputtedPassword == $password) {
$loggedIn = new Zend_Session_Namespace('loggedIn');
$loggedIn->success;
$this->_forward('index', 'home');
} else {
echo 'invalid';
}
}
我有一个家庭控制器,只有登录的用户才能看到,所以在 init 函数中我有: $loggedIn = new Zend_Session_Namespace('loggedIn');
if (isset($loggedIn->success)) {
echo 'success';
}else{
$url = $this->view->url(array(
'controller' => 'index',
'action' => 'index'));
header('Location:' . $url);
}
}
当我使用正确的凭据登录时,它会将我重定向到其他功能中所述的登录屏幕。
我究竟做错了什么?