[英]how to use PHP session variable in zend framework
我想知道如何在zend框架中使用PHP會話變量
這是我到目前為止的代碼: -
public function loginAction()
{
$this->view->title = 'Login';
if(Zend_Auth::getInstance()->hasIdentity()){
$this->_redirect('index/index');
}
$request = $this->getRequest();
$form = new Default_Form_LoginForm();
if($request->isPost()){
if($form->isValid($this->_request->getPost())){
$authAdapter = $this->getAuthAdapter();
$username = $form->getValue('username');
$password = $form->getValue('password');
$authAdapter->setIdentity($username)
->setCredential($password);
$auth = Zend_Auth::getInstance();
$result = $auth->authenticate($authAdapter);
if($result->isValid()){
$identity = $authAdapter->getResultRowObject();
print_r($authAdapter->getResultRowObject());
$authStorage = $auth->getStorage();
$authStorage->write($identity);
echo $authAdapter->getIdentity() . "\n\n";
// $this->_redirect('index/index');
} else {
$this->view->errorMessage = "User name or password is wrong.";
}
}
}
$this->view->form = $form;
}
現在我想在會話中存儲用戶名,我想在其他一些頁面中使用
echo "welcome," .$this->username;
我可以做什么 ?
您可以存儲自定義對象或模型,而不是將$identity
寫入$identity
$authStorage
。
這是一個例子:
<?php
class Application_Model_UserSession
implements Zend_Acl_Role_Interface
{
public $userId;
public $username;
/** @var array */
protected $_data;
public function __construct($userId, $username)
{
$this->userId = $userId;
$this->username = $username;
}
public function __set($name, $value)
{
$this->_data[$name] = $value;
}
public function __get($name)
{
if (array_key_exists($name, $this->_data)) {
return $this->_data[$name];
} else {
return null;
}
}
public function updateStorage()
{
$auth = Zend_Auth::getInstance();
$auth->getStorage()->write($this);
}
public function getRoleId()
{
// TODO: implement
$role = 'guest';
return $role;
}
public function __isset($name)
{
return isset($this->_data[$name]);
}
public function __unset($name)
{
unset($this->_data[$name]);
}
}
現在在您的登錄控制器中,您可以:
if($result->isValid()){
$identity = new Application_Model_UserSession(0, $username); // 0 for userid
// You can also store other data in the session, e.g.:
$identity->account = new Account_Model($authAdapter->getResultRowObject());
$identity->updateStorage(); // update Zend_Auth identity with the UserSession object
通常,我有一個帳戶對象,我也存儲在UserSession對象中,並通過公共屬性輕松訪問用戶名和userId。
現在您可以隨時獲取對象:
$identity = Zend_Auth::getInstance()->getIdentity(); // Application_Model_UserSession
只是不要忘記確保它是Application_Model_UserSession。
雖然您可以創建Zend_Session類對象,但我建議使用Zend_Session_Namespace對象。 您可以將會話實例化為:
$sess = new Zend_Session_Namespace('MyNamespace');
如果不通過,Zend會話名稱空間將為其名稱分配一個字符串“default”。 要存儲值,您需要執行以下操作:
$sess->username = 'you_name';
稍后在代碼中,您需要執行以下操作以從會話中檢索值:
$session = new Zend_Session_Namespace('MyNamespace');
$userName = $sess->username;
希望能幫助到你
在這種情況下,它應該像繼續將數據添加到$ authStorage一樣簡單:
$authStorage = $auth->getStorage();
$authStorage->write($identity);
$authStorage->write($username);
稍后在另一個動作或控制器中,您可以使用Zend_Auth :: getStorage來調用您的數據或使用Zend_Session_Namespace。
$authStorage = $auth->getStorage();
$authStorage->read($identity);
$authStorage->read($username);
要么
$session = new Zend_Session_Namespace('Zend_Auth'); //Zend_Auth uses Zend_Session_Namespace for storage
$username = $session->username;
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.