2014-02-14 5 views
0

나는 FOSUserBundle과 FOSFacebookBundle을 함께 사용합니다. 내가 볼Symfony2 : "/ login_check"경로에 대한 컨트롤러를 찾을 수 없습니다.

FOSUserBundleFOSFacebookBundle

나는 페이스 북 버튼을 사용하여 로그인 :

Unable to find the controller for path "/login_check". Maybe you forgot to add the matching route in your routing configuration?<br /> 
404 Not Found - NotFoundHttpException</p> 

응용 프로그램/설정/aonfig.cfg

나는 공식 문서 준수를 설정
imports: 
    - { resource: parameters.yml } 
    - { resource: security.yml } 

framework: 
    #esi:    ~ 
    translator:  { fallback: "%locale%" } 
    secret:   "%secret%" 
    router: 
     resource: "%kernel.root_dir%/config/routing.yml" 
     strict_requirements: ~ 
    form:   ~ 
    csrf_protection: ~ 
    validation:  { enable_annotations: true } 
    templating: 
     engines: ['twig'] 
     #assets_version: SomeVersionScheme 
    default_locale: "%locale%" 
    trusted_hosts: ~ 
    trusted_proxies: ~ 
    session: 
     # handler_id set to null will use default session handler from php.ini 
     handler_id: ~ 
    fragments:  ~ 
    http_method_override: true 

# Twig Configuration 
twig: 
    debug:   "%kernel.debug%" 
    strict_variables: "%kernel.debug%" 

# Assetic Configuration 
assetic: 
    debug:   "%kernel.debug%" 
    use_controller: false 
    bundles:  [ ] 
    #java: /usr/bin/java 
    filters: 
     cssrewrite: ~ 
     #closure: 
     # jar: "%kernel.root_dir%/Resources/java/compiler.jar" 
     #yui_css: 
     # jar: "%kernel.root_dir%/Resources/java/yuicompressor-2.4.7.jar" 

# Doctrine Configuration 
doctrine: 
    dbal: 
     driver: "%database_driver%" 
     host:  "%database_host%" 
     port:  "%database_port%" 
     dbname: "%database_name%" 
     user:  "%database_user%" 
     password: "%database_password%" 
     charset: UTF8 
     # if using pdo_sqlite as your database driver, add the path in parameters.yml 
     # e.g. database_path: "%kernel.root_dir%/data/data.db3" 
     # path:  "%database_path%" 

    orm: 
     auto_generate_proxy_classes: "%kernel.debug%" 
     auto_mapping: true 

# Swiftmailer Configuration 
swiftmailer: 
    transport: "%mailer_transport%" 
    host:  "%mailer_host%" 
    username: "%mailer_user%" 
    password: "%mailer_password%" 
    spool:  { type: memory } 

services: 
    my.facebook.user: 
     class: ISS\BlogBundle\Security\User\Provider\FacebookProvider 
     arguments: 
      facebook: "@fos_facebook.api" 
      userManager: "@fos_user.user_manager" 
      validator: "@validator" 

# FOSUserBundle Configuration 
fos_user: 
    db_driver: orm 
    firewall_name: main 
    user_class: ISS\BlogBundle\Entity\User 

# FOSFacebookBundle Configuration 
fos_facebook: 
    alias: facebook 
    app_id: *myId* 
    secret: *mySecret* 
    cookie: true 
    permissions: [email, user_birthday, user_location] 

/app/config/security.yml

security: 
    encoders: 
     FOS\UserBundle\Model\UserInterface: sha512 

    role_hierarchy: 
     ROLE_ADMIN:  ROLE_USER 
     ROLE_SUPER_ADMIN: [ROLE_USER, ROLE_ADMIN, ROLE_ALLOWED_TO_SWITCH] 

    providers: 
     chain_provider: 
      chain: 
       providers: [fos_userbundle, my_fos_facebook_provider] 
     fos_userbundle: 
      id: fos_user.user_provider.username 
     my_fos_facebook_provider: 
      id: my.facebook.user 

    firewalls: 
     dev: 
      pattern: ^/(_(profiler|wdt)|css|images|js)/ 
      security: false 
     main:`enter code here` 
      pattern: ^/ 
      switch_user: true 
      form_login: 
       provider: fos_userbundle 
       csrf_provider: form.csrf_provider 
      logout: true 
      anonymous: true 
     public: 
      pattern: ^/.* 
      fos_facebook: 
       app_url: "http://apps.facebook.com/669439826427579/" 
       server_url: "http://issart-company.loc/" 
       login_path: /login 
       check_path: /login_check 
       default_target_path:/
       provider: my_fos_facebook_provider 
      anonymous: true 

    access_control: 
     - { path: ^/login$, role: IS_AUTHENTICATED_ANONYMOUSLY } 
     - { path: ^/register, role: IS_AUTHENTICATED_ANONYMOUSLY } 
     - { path: ^/resetting, role: IS_AUTHENTICATED_ANONYMOUSLY } 
     - { path: ^/admin/, roles: ROLE_ADMIN } 
     - { path: ^/secured/.*, role: [IS_AUTHENTICATED_FULLY] } # This is the route secured with fos_facebook 
     - { path: ^/.*, role: [IS_AUTHENTICATED_ANONYMOUSLY] } 
     - { path: ^/facebook/, role: [ROLE_FACEBOOK] } 

응용 프로그램/설정/앱에서

iss_blog: 
    resource: "@ISSBlogBundle/Resources/config/routing.yml" 
    prefix: /

_security_check: 
    pattern: /login_check 

_security_logout: 
    pattern: /logout 

fos_facebook_channel: 
    resource: "@FOSFacebookBundle/Resources/config/routing.xml" 

fos_user_security: 
    resource: "@FOSUserBundle/Resources/config/routing/security.xml" 

fos_user_profile: 
    resource: "@FOSUserBundle/Resources/config/routing/profile.xml" 
    prefix: /profile 

fos_user_register: 
    resource: "@FOSUserBundle/Resources/config/routing/registration.xml" 
    prefix: /register 

fos_user_resetting: 
    resource: "@FOSUserBundle/Resources/config/routing/resetting.xml" 
    prefix: /resetting 

fos_user_change_password: 
    resource: "@FOSUserBundle/Resources/config/routing/change_password.xml" 
    prefix: /profile 

_facebook_secured: 
    pattern: /secured/ 
    defaults: { _controller: ISSBlogBundle:Post:index } 

답변

0

라우팅/설정/당신이 할당 된 컨트롤러없이/login_check을 라우팅. 이 같은 컨트롤러를 구성 할 필요가 :

_security_check: 
    pattern: /login_check 
    defaults: { _controller: ACMEBundle:Controller:action } 

당신은 http://symfony.com/doc/current/book/routing.html

에서 자세한 정보를 찾을 수 있습니다 지금 라우팅 시스템이 처음 대신 @ FOSUserBundle/자원/설정/라우팅/보안 "에 구성된 하나를 발견한다. xml ". FOSUserBundle이 로그인 프로세스를 처리하게하려면 _security_check 및 _security_logout 라우트를 삭제해야합니다.

+0

나는 이것을 'defaults : {_controller : FOSUserBundle : Security : login}'이라고 쓰고 로그인 페이지로 리디렉션되었습니다. 그러나 나는 아직도 허가하지 않았다. – FIMAk

+0

FOSUserBundle이 로그인, 로그 아웃 등을 처리하게하려면'_security_check' 및'_security_logout'을 제거해야합니다. 제어기가있는 경로는 "@FOSUserBundle/Resources/config/routing/security.xml"에 정의되어 있습니다. 자신을 컨트롤러로 정의하고 싶다면'/ login_check'에 대해 'FOSUserBundle : Security : check'를 사용하십시오. –

+0

해답을 가져 주셔서 감사합니다. 그러나 routing.yml에서'_security_check'와'_security_logout'을 제거 할 경우보기 스크립트에서 제거해야합니다. function goLogIn() { window.location.href = "{{path ('_ security_check ')}} "; } ' – FIMAk