Php Symfony 4-两个防火墙导致错误太多重定向

Php Symfony 4-两个防火墙导致错误太多重定向,php,symfony,symfony4,Php,Symfony,Symfony4,我写这篇文章是因为以前的答案没有帮助。主防火墙似乎工作得很好,管理员是造成问题的人。每次我尝试输入它应该重定向到的路径时,都会进入重定向循环,并因上面指定的错误而崩溃 安全.yaml security: encoders: App\Entity\User: algorithm: bcrypt Symfony\Component\Security\Core\User\User: plaintext role_hierarchy: ROLE_ADMIN:

我写这篇文章是因为以前的答案没有帮助。主防火墙似乎工作得很好,管理员是造成问题的人。每次我尝试输入它应该重定向到的路径时,都会进入重定向循环,并因上面指定的错误而崩溃

安全.yaml

security:
encoders:
    App\Entity\User:
        algorithm: bcrypt
    Symfony\Component\Security\Core\User\User: plaintext
role_hierarchy:
    ROLE_ADMIN:       ROLE_USER
    ROLE_SUPER_ADMIN: ROLE_ADMIN
providers: 
    chain_provider:
            chain:
                providers: [in_memory, db_provider]
    in_memory:
        memory:
            users:
               theadmin:
                    password: iamadmin
                    roles: 'ROLE_SUPER_ADMIN'
    db_provider:
        entity:
            class: App\Entity\User
            property: email
firewalls:
    dev:
        pattern: ^/(_(profiler|wdt)|css|images|js)/
        security: false

    admin:
        pattern: /admin
        anonymous: ~

        form_login: 
            username_parameter: _username
            login_path: /admin_login
            check_path: /admin_login
            provider: in_memory
            default_target_path: admin

        logout:
            path: /admin_logout
            target: /


    main:
        pattern: /
        anonymous: ~

        form_login: 
            username_parameter: _email
            login_path: /login
            check_path: /login
            provider: db_provider
            default_target_path: welcome

        logout:
            path: /logout
            target: /
access_control:
- { path: ^/welcome, roles: ROLE_USER }
- { path: ^/admin, roles: ROLE_SUPER_ADMIN }
- { path: ^/login, roles: IS_AUTHENTICATED_ANONYMOUSLY }
- { path: ^/admin_login, roles: IS_AUTHENTICATED_ANONYMOUSLY }
AdminSecurityController.php

namespace App\Controller;

use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
use Symfony\Component\Routing\Annotation\Route;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\Security\Http\Authentication\AuthenticationUtils;

class AdminSecurityController extends AbstractController
{
    /**
     * @Route("/admin_login", name="admin_login")
     */

    public function admin_login(Request $request, AuthenticationUtils $utils)
    {
        $error = $utils->getLastAuthenticationError();

        $auth_checker = $this->get('security.authorization_checker');

        if ($auth_checker->isGranted('ROLE_SUPER_ADMIN')) {
            return $this->render('admin/dashboard.html.twig', [
                'controller_name' => 'AdminController',
            ]);
                } else{
                    return $this->render('admin_security/admin_login.html.twig', [
                        'error' => $error
                    ]);
        }
    }

    /**
     * @Route("/admin_logout", name="admin_logout")
     */

    public function admin_logout()
    {

    }
}

访问控制条目从中进行分析。因此,您需要将^/admin_登录项放在^/admin之前

想象一下安全组件当前是如何设置的:

您访问登录表单,然后按提交 您的来宾将被重定向到/admin\u登录路径 安全组件遍历这些条目,并将/admin_登录名与^/admin条目匹配 因为它需要角色\u SUPER\u ADMIN,所以最终会出现一个循环
请记住在之后清除缓存。

访问控制项将从中进行分析。因此,您需要将^/admin_登录项放在^/admin之前

想象一下安全组件当前是如何设置的:

您访问登录表单,然后按提交 您的来宾将被重定向到/admin\u登录路径 安全组件遍历这些条目,并将/admin_登录名与^/admin条目匹配 因为它需要角色\u SUPER\u ADMIN,所以最终会出现一个循环
记得在之后清除缓存。

谢谢!成功了。但是现在我也一直被重定向到/admin_login而不是/login,即使在我访问/welcomer时也是如此。根据上面的评论,现在一切都很好。看来我不小心从模式中删除了admin:/admin很高兴我能帮忙。谢谢!成功了。但是现在我也一直被重定向到/admin_login而不是/login,即使在我访问/welcomer时也是如此。根据上面的评论,现在一切都很好。看来我不小心从模式中删除了admin:/admin很高兴我能帮上忙。