Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/298.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/macos/8.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Php 如何在向Silex中的自定义用户提供商注册后自动登录新用户?_Php_Silex - Fatal编程技术网

Php 如何在向Silex中的自定义用户提供商注册后自动登录新用户?

Php 如何在向Silex中的自定义用户提供商注册后自动登录新用户?,php,silex,Php,Silex,上下文:我为我的Silex应用程序创建了一个自定义用户提供程序,现在我可以完美地注册和记录我自己的用户。但是,我现在需要在注册后自动登录我的用户,这不起作用 这是我的安全部分: 'secured' => array( 'pattern' => '^/', 'anonymous' => false, 'form' => array('login_path' => '/login', 'check_path' =>

上下文:我为我的Silex应用程序创建了一个自定义用户提供程序,现在我可以完美地注册和记录我自己的用户。但是,我现在需要在注册后自动登录我的用户,这不起作用

这是我的安全部分:

'secured' => array(
        'pattern' => '^/',
        'anonymous' => false,
        'form' => array('login_path' => '/login', 'check_path' => '/login_check'),
        'logout' => array('logout_path' => '/logout', 'invalidate_session' => true),
        'users' => $app->share(function () use ($app) {
            return new Partner\DAO\PartnerDAO($app['db']);
        })
    )
这是我的userProviderInterface:

public function refreshUser(UserInterface $user)
{
    if (!$user instanceof Partner) {
        throw new UnsupportedUserException(sprintf('Instances of "%s" are not supported.', get_class($user)));
    }

    return $this->loadUserByUsername($user->getUsername());
}


public function supportsClass($class)
{
    return 'Partner\Entity\Partner' === $class;
}
使用Xdebug,我可以在这里看到:

  foreach ($this->userProviders as $provider) {
        try {
            $refreshedUser = $provider->refreshUser($user);
            $token->setUser($refreshedUser);

            if (null !== $this->logger) {
                $this->logger->debug('User was reloaded from a user provider.', array('username' => $refreshedUser->getUsername(), 'provider' => get_class($provider)));
            }

            return $token;
$this->userProviders
仅包含一个提供程序:
'Users'=>null

请注意:

登录,注册和注销工作完美。只有当我想在注册后自动登录我的用户时,才会触发此错误。代码如下:

$token = new UsernamePasswordToken($partner, null, 'secured', $partner->getRoles());
// Note that $partner->getRoles()  is array('ROLE_USER')
$app['security.token_storage']->setToken($token);
return $app->redirect($app["url_generator"]->generate("partner_home"));
注册后,我会自动创建令牌并在安全区域重定向用户,但Silex会在登录页面上重定向它,如果我单击某个地方,我会得到:

用户“Partner\Entity\Partner”没有用户提供程序


我不知道在哪里搜索,我真的需要一些帮助。

找到了一个解决方案,更像是一个解决办法,但它使工作:

现在,我不再使用security/token方法,而是通过向login\u check控制器生成一个请求来记录用户,以便生成所有必要的登录事件

在我的控制器中:

$subRequest = Request::create(
$app['url_generator']->generate('login_check'),
    'POST',
    array(
        '_username' => $partner->getEmail(),
        '_password' => $rawPassword,
        $request->cookies->all(),
        array(),
        $request->server->all()
    )
);
$app->handle($subRequest, HttpKernelInterface::MASTER_REQUEST, false);
在防火墙配置中需要“'require\u previous\u session'=>false”:

'secured' => array(
        'pattern' => '^/',
        'anonymous' => false,
        'form' => array(
            'login_path' => '/login',
            'check_path' => '/login_check',
            'require_previous_session' => false
        ),
        'logout' => array('logout_path' => '/logout', 'invalidate_session' => true),
        'users' => $app->share(function () use ($app) {
            return new Partner\DAO\PartnerDAO($app['db']);
        })
    )

我不确定这是一个好的还是一个坏的解决方案,但它正在工作。

您的更新看起来像是一个答案。你会考虑把它变成一个恰当的答案吗?如果其他人愿意,他们仍然可以添加答案。我也有同样的问题,已解决: