Как использовать Zend \ Session в zf2?

В вашем контексте.xml, если у вас есть объявление xsd для безопасности:

xmlns:security="http://www.springframework.org/schema/security",

Внутри элемента <security:http> добавьте

<security:csrf disabled="true"/>
29
задан SagarPPanchal 25 June 2014 в 07:29
поделиться

7 ответов

Некоторые примеры использования сеансов zf2:

Создание сеанса:

use Zend\Session\Container;
$session = new Container('base');

Убедитесь, что ключ существует в сеансе:

$session->offsetExists('email')

Получение значения из сеанса с помощью клавиша:

$email = $session->offsetGet('email');

Установка значения в сеансе:

$session->offsetSet('email', $email);

Сброс значения в сеансе:

$session->offsetUnset('email');

И другой простой способ использования сеанса:

$session = new Container('foo');

// это все эквивалентные средства для одного и того же конца

$session['bar'] = 'foobar';

$session->bar = 'foobar';

$session->offsetSet('bar', 'foobar'); 
68
ответ дан minc 25 June 2014 в 07:29
поделиться

Сейчас я работаю с zf2. Я нашел использование Сессий в:

Zend\Authentication\Storage\Session.php

Может быть, вы можете найти свой ответ там.

3
ответ дан Coreus 25 June 2014 в 07:29
поделиться

Определенно, да, вы должны использовать Zend \ Session \ Container

Контейнер расширяет ArrayObject и создает экземпляр с флагом ARRAY_AS_PROPS, что означает, что вы можете легко перебирать свойства и читать / писать их, например,

use Zend\Session\Container as SessionContainer;

$this->session = new SessionContainer('post_supply');
$this->session->ex = true;
var_dump($this->session->ex);

Первый аргумент - это пространство имен сессии, а второй - Manager . Manager является фасадом для Storage и SaveHandler и настроен на ConfigInterface для сохранения данных сеанса в БД или на сервере Memcache.

17
ответ дан Blackcoat77 25 June 2014 в 07:29
поделиться

хорошо вот краткий пример. Я реализовал в отношении поддержания сеанса при успешной аутентификации пользователя.

<?php
$registry = Zend_Registry::getInstance();
$DB = $registry['DB'];
$authAdapter = new Zend_Auth_Adapter_DbTable($DB);
$authAdapter->setTableName('user');
$authAdapter->setIdentityColumn("user_name");
$authAdapter->setCredentialColumn("user_password");
//get values
$username = $request->getParam('username');
$password = $request->getParam('password');
//set values
$authAdapter->setIdentity($username);
$authAdapter->setCredential($password);

$auth = Zend_Auth::getInstance();
//to store in session
$auth->setStorage(new Zend_Auth_Storage_Session('front'));

$authResult = $auth->authenticate($authAdapter);
if ($authResult->isValid()) {
    $authAdap = $authAdapter->getResultRowObject(null, "Password");
    $auth->getStorage()->write($authAdap);
    $this->_redirect('/login/controlpannel');
} else {
    $this->_redirect('/login/login');
}
?>

получение значений или проверка данных, сохраненных в сеансе, связанных с пользователем

<?php
$auth = Zend_Auth::getInstance();
$auth->setStorage(new Zend_Auth_Storage_Session('front'));
 if($auth->hasIdentity()){
     $data = $auth->getStorage()->read();
     print_r($data);
 }else{
     $this->_redirect('/login/login');
 }
?>

надеюсь, что это может кому-то помочь

0
ответ дан zoomi 25 June 2014 в 07:29
поделиться

Чтобы начать сеанс, вам нужно использовать

zend\session\container
-1
ответ дан michaelbn 25 June 2014 в 07:29
поделиться

Если вы пытаетесь использовать сеанс в действии входа в систему, вы можете использовать: «Zend\Authentication\AuthenticationService». Он также аутентифицирует пользователя и сеанс хранилища.

getStorage()->write($contents) сохранит сеанс.

1
ответ дан Blackcoat77 25 June 2014 в 07:29
поделиться
use Zend\Session\Container; 

public function createAction(){
  $session = new Container('name');
  $session->offsetSet('session_variable', $value);
}
//the above codes are used for create session.

public function take_valuesAction(){ 
  $session = new Container('name');
  echo $value = $session->offsetGet('session_variable');
}
//the above codes are used for take values from session.

public function destroyAction(){ 
  $session = new Container('name');
  $session->getManager()->destroy();
}
//the above codes are used for destroy the session.
0
ответ дан Hajis Hakkim 25 June 2014 в 07:29
поделиться
Другие вопросы по тегам:

Похожие вопросы: