Symfony 5 PHP8 安全属性
Symfony 5 PHP8 Attributes for Security
我有一个页面,我正在尝试将其从注释转换为 PHP8 属性。
namespace App\Controller;
use Sensio\Bundle\FrameworkExtraBundle\Configuration\IsGranted;
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
use Symfony\Component\HttpFoundation\Response;
use Symfony\Component\Routing\Annotation\Route;
#[IsGranted('ROLE_ADMIN')]
#[Route('/page')]
class PageController extends AbstractController
{
#[Route('/', name: 'page')]
public function index(): Response
{
return $this->render('page/index.html.twig', [
'controller_name' => 'PageController',
]);
}
}
IsGranted
属性似乎不起作用,因为页面是可访问的而不是 403 错误。另一方面,当转换为注释时,如下所示,它按预期工作。是否缺少我的配置设置?
/**
* @IsGranted("ROLE_ADMIN")
*/
#[Route('/page')]
class PageController extends AbstractController
{
#[Route('/', name: 'page')]
public function index(): Response
{
return $this->render('page/index.html.twig', [
'controller_name' => 'PageController',
]);
}
}
其他属性,例如 #[Route]
、#[Entity]
等有效,但安全属性似乎不起作用。
仅从版本 6.1.0 开始支持 SensioFrameworkExtraBundle
包中的 PHP8 属性。您可能只需要更新它。
我有一个页面,我正在尝试将其从注释转换为 PHP8 属性。
namespace App\Controller;
use Sensio\Bundle\FrameworkExtraBundle\Configuration\IsGranted;
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
use Symfony\Component\HttpFoundation\Response;
use Symfony\Component\Routing\Annotation\Route;
#[IsGranted('ROLE_ADMIN')]
#[Route('/page')]
class PageController extends AbstractController
{
#[Route('/', name: 'page')]
public function index(): Response
{
return $this->render('page/index.html.twig', [
'controller_name' => 'PageController',
]);
}
}
IsGranted
属性似乎不起作用,因为页面是可访问的而不是 403 错误。另一方面,当转换为注释时,如下所示,它按预期工作。是否缺少我的配置设置?
/**
* @IsGranted("ROLE_ADMIN")
*/
#[Route('/page')]
class PageController extends AbstractController
{
#[Route('/', name: 'page')]
public function index(): Response
{
return $this->render('page/index.html.twig', [
'controller_name' => 'PageController',
]);
}
}
其他属性,例如 #[Route]
、#[Entity]
等有效,但安全属性似乎不起作用。
仅从版本 6.1.0 开始支持 SensioFrameworkExtraBundle
包中的 PHP8 属性。您可能只需要更新它。