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 理解路径和路由名称。
我 运行 第一次遇到 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 理解路径和路由名称。