我想有两种不同的(我指的是不同的模板)表单,可以在不同的树枝中登录我的用户。但我从我的一个表单中得到一个错误...这就是我一步一步做的:Symfony2 FOSUser/SonataBundle无效的CSRF令牌值
我有路线/login
上的主要登录模板。 此登录帐号可以使用!。
要在/product_frm
第二种形式的工作,我这样做:)创造了第二次登录控制器的路线
1。所以现在我有两个登录路线:
login:
path: /login
defaults: { _controller: ApplicationSonataUserBundle:SecurityFOSUser1:login }
loginForm:
path: /login_frm
defaults: { _controller: ApplicationSonataUserBundle:LoginFormType:login }
现在,这是为/login_frm
这是相同的/login
控制器控制器,只呈现模板是不同的:
<?php
/*
* This file is part of the Sonata package.
*
* (c) Thomas Rabaix <[email protected]>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace Application\Sonata\UserBundle\Controller;
use FOS\UserBundle\Controller\SecurityController;
use Sonata\UserBundle\Model\UserInterface;
use Symfony\Component\HttpFoundation\RedirectResponse;
use Sonata\UserBundle\Controller\SecurityFOSUser1Controller as BaseController;
class LoginFormTypeController extends BaseController
{
public function loginAction()
{
$user = $this->container->get('security.context')->getToken()->getUser();
if ($user instanceof UserInterface) {
$this->container->get('session')->getFlashBag()->set('sonata_user_error', 'sonata_user_already_authenticated');
$url = $this->container->get('router')->generate('sonata_user_profile_show');
return new RedirectResponse($url);
}
return parent::loginAction();
}
public function renderLogin(array $data)
{
$template = sprintf('MpShopBundle:Form:login_form2.html.%s', $this->container->getParameter('fos_user.template.engine'));
return $this->container->get('templating')->renderResponse($template, $data);
}
}
最后,我制作加载表单的模板:
{% block fos_user_content %}
<div class="span9">
<div class="well">
{% block sonata_user_login %}
<div class="panel panel-info">
<div class="panel-heading">
<h2 class="panel-title">{{ 'title_user_authentication'|trans({}, 'SonataUserBundle') }}</h2>
</div>
<div class="panel-body">
{% block sonata_user_login_error %}
{% if error %}
<div class="alert alert-danger alert-error">{{ error|trans({}, 'FOSUserBundle') }}</div>
{% endif %}
{% endblock %}
{% block sonata_user_login_form %}
<form action="{{ path("fos_user_security_check") }}" method="post" role="form"
class="form-horizontal">
<input type="hidden" name="_csrf_token" value="{{ csrf_token }}"/>
<div class="control-group">
<label class="control-label control-label required" for="username"
class="col-sm-4 control-label">{{ 'security.login.username'|trans({}, 'SonataUserBundle') }}</label>
<div class="controls">
<input type="text" class="form-control" id="username" name="_username" value="{{ last_username }}" required="required"/></div>
</div>
<div class="form-group control-group">
<label class="control-label control-label required" for="password"
class="col-sm-4 control-label">{{ 'security.login.password'|trans({}, 'SonataUserBundle') }}</label>
<div class="controls">
<input type="password" class="form-control" id="password" name="_password" required="required"/></div>
</div>
<div class="control-group">
<div class="col-sm-offset-4 col-sm-8">
<div class="checkbox control-group">
<label class="checkbox pull-left" for="remember_me">
<input type="checkbox" id="remember_me" name="_remember_me" value="on"/>
{{ 'security.login.remember_me'|trans({}, 'FOSUserBundle') }}
</label>
</div>
</div>
</div>
<div class=" control-group pull-left">
<div class="">
<a href="{{ path('forgetpass') }}">{{ 'forgotten_password'|trans({}, 'SonataUserBundle') }}</a>
</div>
</div>
<div class="form-actions">
<div class="pull-left">
<input type="submit" id="_submit" name="_submit" class="btn btn-primary pull-right"
value="{{ 'security.login.submit'|trans({}, 'FOSUserBundle') }}"/>
</div>
</div>
</form>
{% endblock %}
</div>
</div>
{% endblock %}
</div>
</div>
{% endblock fos_user_content %}
The ful l错误:如果我尝试登录/login_frm
,我得到Invalid CSRF token.
错误。如果我从/login
登录,它工作正常。这是为什么?不能我有两种形式登录?
[CSRF令牌无效。请尝试重新提交表单](http://stackoverflow.com/questions/23455780/the-csrf-token-is-invalid-please-try-to-resubmit-the-form) –
它不是重复的,ty: ) – Dominykas55