Я решил.
Существует решение: How to disable redirection after login_check in Symfony 2
и вот код, который решает мою проблему:
<?php
namespace Acme\MainBundle\Handler;
use Symfony\Component\Security\Http\Logout\LogoutSuccessHandlerInterface;
use Symfony\Component\Security\Http\Authentication\AuthenticationFailureHandlerInterface;
use Symfony\Component\Security\Core\Exception\AuthenticationException;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\HttpFoundation\RedirectResponse;
class AuthenticationHandler implements AuthenticationFailureHandlerInterface, LogoutSuccessHandlerInterface
{
public function onAuthenticationFailure(Request $request, AuthenticationException $exception)
{
$referer = $request->headers->get('referer');
$request->getSession()->setFlash('error', $exception->getMessage());
return new RedirectResponse($referer);
}
public function onLogoutSuccess(Request $request)
{
$referer = $request->headers->get('referer');
return new RedirectResponse($referer);
}
}
для обработки событий добавить в security.yml, например:
form_login:
check_path: /access/login_check
login_path:/
use_referer: true
failure_handler: authentication_handler
logout:
path: /access/logout
target:/
success_handler: authentication_handler
и CONFIG .yml:
services:
authentication_handler:
class: Acme\MainBundle\Handler\AuthenticationHandler
Почему бы не путь сбоя просто приглашение для входа? – JamesHalsall
, потому что я могу войти с каждой подстраницы. У меня нет одной формы для регистрации на указанном URL-адресе, поэтому я не хочу перенаправлять пользователя на главную страницу, когда он заходит с другой страницы профиля пользователя. –