0

我在我的应用程序中使用 ZfcUser,我需要控制超时参数。由于它不是配置的一部分,我想在引导程序上将我自己的 Zend/Session 对象(带有remember_me_seconds参数)设置为 ZfcUser,但我不知道如何。

碰巧,有人已经这样做了吗?

4

3 回答 3

1

设置会话参数的最简单方法如下 config\autoload\global.php

return array(
    'service_manager' => [
        'factories' => [
            // Configures the default SessionManager instance
            'Zend\Session\ManagerInterface' => 'Zend\Session\Service\SessionManagerFactory',
            // Provides session configuration to SessionManagerFactory
            'Zend\Session\Config\ConfigInterface' => 'Zend\Session\Service\SessionConfigFactory',
        ],
    ],
    'session_manager' => [
        // SessionManager config: validators, etc
    ],
    'session_config' => [
        'cache_expire' => 86400,
        'cookie_lifetime' => 86400,
        'remember_me_seconds' => 86400,
        'gc_probability' => 10,
        'gc_divisor' => 1000,
        'use_cookies' => true,
        'cookie_httponly' => true,
        'cookie_lifetime' => 0, // to reset lifetime to maximum at every click
        'gc_maxlifetime' => 86400,
    ],
);

onBootstrap并在方法中添加行Module.php

public function onBootstrap(MvcEvent $e)
{
    $manager = $e->getApplication()->getServiceManager()->get('Zend\Session\ManagerInterface');
}

这将影响会话设置并phpinfo()显示它。

我在zfcuser github中找到了它

于 2015-09-14T08:49:30.660 回答
0

我不使用 zfcuser 但试试这个

自动加载/global.php

<?php

use Zend\Session\Config\SessionConfig;
use Zend\Session\SessionManager;
use Zend\Session\Container;

return array(
    'service_manager' => array(
        'factories' => array(
            'SessionManager' => function($sm) {
                $sessionConfig = new SessionConfig();
                $sessionConfig->setOption('remember_me_seconds', 1440);

                $sessionManager = new SessionManager($sessionConfig);
                Container::setDefaultManager($sessionManager);

                return $sessionManager;
            },
        ),
    ),
);

模块.php

public function onBootstrap($event)
{
    $serviceManager = $event->getApplication()->getServiceManager();
    $serviceManager->get('SessionManager')->start();
}
于 2014-02-23T12:37:04.620 回答
0

这是我的做法。我不是世界上最伟大的程序员,但这似乎可行。这都在 Module.php 中

public function onBootstrap(MvcEvent $e)
{
    $eventManager        = $e->getApplication()->getEventManager();
    $sharedManager       = $eventManager->getSharedManager();
    $sm = $e->getApplication()->getServiceManager();        
    //This checks to see if the user is logged in. 
    $eventManager->attach(MvcEvent::EVENT_DISPATCH, array($this, 'checkLogin'), 100);


}

//This function is attached to a listener to see if the user is not currently logged in
//If they are not logged in they will be redirected to the login page. This check will happen through the 
//application so there is no need to keep checking in other modules
public function checkLogin (MvcEvent $e)
{



    $session = new Container('defaults');        
    $this->route = $e->getRouteMatch();
    $this->matchedRouteName = explode('/', $this->route->getMatchedRouteName());
    $this->route_root = $this->matchedRouteName[0];
    $sm = $e->getApplication()->getServiceManager();

    $zfcServiceEvents = $sm->get('ZfcUser\Authentication\Adapter\AdapterChain')->getEventManager();

    $zfcServiceEvents->attach(
            'authenticate',
            function ($e) use ($session) {
            $session->offsetSet('sessionstart', $_SERVER['REQUEST_TIME']);
            }
    );  

    $auth = $sm->get('zfcuser_auth_service');

    if (!$auth->hasIdentity() && $this->route_root != 'zfcuser')
     { 
        $response = new \Zend\Http\PhpEnvironment\Response();
        $response->getHeaders()->addHeaderLine('Location', '/user/login');
        $response->setStatusCode(302);
        $response->sendHeaders();
        $e->stopPropagation(true);
        return $response;
    }

   else if ($auth->hasIdentity() && $session->offsetGet('sessionstart') < ($_SERVER['REQUEST_TIME'] - 10800) && $this->route_root != 'zfcuser')
   {
        $response = new \Zend\Http\PhpEnvironment\Response();
        $response->getHeaders()->addHeaderLine('Location', '/user/logout');
        $response->setStatusCode(302);
                $response->sendHeaders();
                $e->stopPropagation(true);
                return $response;
   }

   else if ($auth->hasIdentity())
   {
    $session->offsetSet('sessionstart', $_SERVER['REQUEST_TIME']);
   }    
}
于 2014-04-04T14:02:56.180 回答