0

マニュアルのセキュリティの例に基づいて symfony2 にログインを実装しようとしていますが、何かが間違っているようで、エラーもメッセージもまったく表示されません。これはコントローラーです:

  <?php

namespace WN\Bundle\UsersBundle\Controller;

use Symfony\Bundle\FrameworkBundle\Controller\Controller;
use Symfony\Component\Security\Core\SecurityContext;
use WN\Bundle\UsersBundle\Entity\User;
use WN\Bundle\UsersBundle\Entity\UsersRepository;

class SecurityController extends Controller {

    public function loginAction() {

        $request = $this->getRequest();
        $session = $request->getSession();

        if($request->attributes->has(SecurityContext::AUTHENTICATION_ERROR))
        {
            $error = $request->attributes->get(SecurityContext::AUTHENTICATION_ERROR);

        }
        else
        {
            $error = $session->get(SecurityContext::AUTHENTICATION_ERROR);
            $session->remove(SecurityContext::AUTHENTICATION_ERROR);
        }
        return $this->render('WNUsersBundle:Security:login.html.twig',
                array('last_username' => $session->get(SecurityContext::LAST_USERNAME),
                        'error' => $error
                        ));
    }

}

?>

アップデート:

これは bundle/config/routing.yml です

wn_home:
    pattern:  /secured
    defaults: { _controller: WNHomeBundle:Home:index }
wn_users_homepage:
    pattern:  /hello/{name}
    defaults: { _controller: WNUsersBundle:Default:index }
wn_users_register:
    pattern:  /register
    defaults: { _controller: WNUsersBundle:Register:register }
wn_users_login:
    pattern:  /login
    defaults: { _controller: WNUsersBundle:Security:login }
login_check:
    pattern:   /login_check

これは security.yml です

jms_security_extra:
    secure_all_services: false
    expressions: true

security:
    encoders:
        Symfony\Component\Security\Core\User\User: plaintext
        WN\Bundle\UsersBundle\Entity\User: sha256
    role_hierarchy:
        ROLE_ADMIN:       ROLE_USER
        ROLE_SUPER_ADMIN: [ROLE_USER, ROLE_ADMIN, ROLE_ALLOWED_TO_SWITCH]

    providers:
         users:
            entity: { class: WNUsersBundle:User }   

    firewalls:
        login:
            pattern:  ^/login
            security: false
        secured_area:
            pattern:    ^/secured
            form_login:
                check_path: /login_check
                login_path: /login
            logout:
                path:   /logout
                target: /login
            #anonymous: ~
            #http_basic:
            #    realm: "Secured Demo Area"

    access_control:
        #- { path: ^/login, roles: IS_AUTHENTICATED_ANONYMOUSLY, requires_channel: https }
         - { path: ^/login$, roles: IS_AUTHENTICATED_ANONYMOUSLY }
         - { path: ^/register, role: IS_AUTHENTICATED_ANONYMOUSLY }

そして、これは login.html.twig です

  {% extends '::base.html.twig' %}
    {% block content %}
    {% if error %}
    <div>{{ error.message }}</div>
    {% endif %}
    <form action="{{ path('login_check') }}" method="post">

    <label for="Username">Username</label>
    <input type="text" name="_username" id="username" value="{{ last_username }}">

    <label for="Password">Password</label>
    <input type="password" name="_password" id="password">
    <br />

    <input  type="submit" name="submit" value="Login">
    </form>

{% endblock %}

今私が得るエラーは次のとおりです。パス「/login_check」のコントローラーが見つかりません。ルーティング構成に一致するルートを追加するのを忘れたのではないでしょうか?

誰もこれを修正する方法を知っていますか?

4

1 に答える 1