he hecho un sistema de acceso a través de autenticación Zend aquí es el códigoZend Zend sesión y autenticación
// userAuthentication
public function authAction(){
$request = $this->getRequest();
$registry = Zend_Registry::getInstance();
$auth = Zend_Auth::getInstance();
$DB = $registry['DB'];
$authAdapter = new Zend_Auth_Adapter_DbTable($DB);
$authAdapter->setTableName('user')
->setIdentityColumn('user_name')
->setCredentialColumn('user_password');
$username = $request->getParam('username');
$password = $request->getParam('password');
$authAdapter->setIdentity($username);
$authAdapter->setCredential($password);
$result = $auth->authenticate($authAdapter);
if($result->isValid()){
$data = $authAdapter->getResultRowObject(null,'password');
$auth->getStorage()->write($data);
$this->_redirect('/login/controlpannel');
}else{
$this->_redirect('/login/login');
}
}
Este trabajo fino ahora. Hay user_id (columna) en el usuario (tabla) donde también hay nombre de usuario y contraseña. Tengo que conseguir que user_id específica de esta tabla que acaba de ingresar y ponerlo en sesión a través de
$user_session = new Zend_Session_Namespace('user_session');
$user_session->username = $username;
$user_id->user_id = $user_id;
para que pueda consultar algo de información en contra de esta $ user_id y pasar el resultado a la vista (nombre) controlpanel
¿por qué quieres poner en sesión de forma manual? Creará la sesión una vez que inicie sesión y puede obtenerla desde el almacenamiento. –
@Teez ¿cómo puedo obtener user_id del almacenamiento? –
$ data = Zend_Auth :: getInstance() -> getStorage() -> read(); $ this-> view-> username = $ data-> user_name; $ this-> view-> id = $ data-> user_id; –