symfony 注销目标从未应用

symfony logout target never applied

我 运行 第一次遇到 Symfony (2.7) 身份验证问题,我真的找不到可行的解决方案。尽管 Symfony 有一个专门的配置选项 logout -> target,但它从未应用于注销,我总是被定向到 /。我可能错过了一些正确实施的限制条件。

好的,我正在使用:

我的config.yml防火墙

secured_area:
        pattern:    ^/
        stateless:  false
        form_login:
            ...
        logout:
            path:   logout
            target: /test
            success_handler: logout_success_handler
        anonymous: ~

为了测试我什至添加了

access_control:
    - { path: ^/test, roles: IS_AUTHENTICATED_ANONYMOUSLY }
    - { path: ^/,     roles: IS_AUTHENTICATED_ANONYMOUSLY }

我正在为路径使用路由名称,路由存在并且工作正常(我可以 login, login_check注销).

我希望通过设置 logout -> target,在注销时我会被重定向到页面 /test。但无论我尝试过什么,直到现在我总是在注销/注销后。

如果有人能指出正确的方向,我会很高兴,如何注销自定义路由(我也已经尝试 target 和路由名称)。非常感谢!

顺便说一句:

我的 logout_success_handler 目前什么都不做。通过启用转储,我还看到,重定向总是转到 / 而不是 /test。

public function onLogoutSuccess(Request $request)
{
    $response = parent::onLogoutSuccess($request);

    //var_dump($response); die;

    return $response;
}

没有内置的注销目标。你必须在你的处理程序中处理它。

步骤 1

将注销目标放入参数文件

parameters:
    logout.target: /test

步骤 2

将您定义注销处理程序的 service.yml 修改为以下内容:

some.logout_handler:
    class: SomeBundle\Security\YourAuthenticationHandler
    arguments: ["@security.context", %logout.target%]

这会将其注入您的处理程序。

步骤 3

最后,在您的 onLogoutSuccess 方法中执行

public function onLogoutSuccess(Request $request)
{
    $response = parent::onLogoutSuccess($request);

    return new RedirectResponse($this->logoutTarget);
}

以及遇到相同问题的人的最终方法。

/**
 * LogoutSuccessHandler
 */
class LogoutSuccessHandler extends DefaultLogoutSuccessHandler implements LogoutSuccessHandlerInterface
{
    /**
     * @var string
     */
    private $logout_route;

    /**
     * Constructor
     * 
     * @param RouterInterface $router
     * @param EntityManager $em
     */
    public function __construct(HttpUtils $httpUtils, $logoutRoute)
    {
        $this->logout_route = $logoutRoute;

        parent::__construct( $httpUtils );
    }

    /**
     * @param Request $request
     * @return Response
     */
    public function onLogoutSuccess(Request $request)
    {
        return $this->httpUtils->createRedirectResponse($request, $this->logout_route);
    }
}

我想使用 httpUtils,因为 createRedirectResponse 理解路径和路由名称。