В файле конфигурации безопасности есть delete_cookies
: http://symfony.com/doc/current/reference/configuration/security.html
У меня включен remember_me
. Все работает нормально, за исключением случаев, когда пользователь переходит по ссылке «выход из системы» (непосредственно из панели URL), я хочу, чтобы Symfony удалила файл cookie REMEMBERME
. Как я могу этого добиться? Я что-то пропустил?
Когда я перехожу по URL-адресу /app/logout
, я вижу инструменты разработчика Chrome, в которых у меня все еще есть файл cookie REMEMBERME
.
Это мой файл security.yml:
firewalls:
app_secured:
anonymous: ~
switch_user: true
pattern: ^(/$|/login$|/app/)
form_login:
login_path: login
check_path: login_check
csrf_provider: form.csrf_provider
default_target_path: index
always_use_default_target_path: true
remember_me:
key: "%secret%"
lifetime: 2592000
path: ~
domain: ~
logout:
invalidate_session: true
delete_cookies:
REMEMBERME: { path: null, domain: null}
path: logout
target: login
access_control:
- { path: ^/app/_sys/, roles: ROLE_NO_ACCESS }
- { path: ^/app/, roles: ROLE_USER }
- { path: ^/app/admin/, roles: ROLE_ADMIN }
Routing.yml
login:
path: /
defaults: { _controller: AppWebBundle:Login:login }
login_check:
path: /login_check
logout:
path: /app/logout
LoginController.php
/**
* Login controller.
* @Route("/")
*/
class LoginController extends Controller
{
/**
* Login page
* @Route("/login", name="login2")
*/
public function loginAction(Request $request){
/** Reduced for simplicity, same code as:
http://symfony.com/doc/current/book/security.html#using-a-traditional-login-form **/
return $this->render('AppWebBundle:Default:login.html.twig', ['last_username' => $lastUsername,'error'=> $error,]);
}
}