dongtang5057 2017-12-24 14:36
浏览 61
已采纳

Symfony 4内核控制器事件监听器 - 实现接口

I want to make some operations before controller load and I have problem with include interfaces or classes into function.

My question is how should I do it to start working?

There is a code:

~/src/Controller/ControllerListener.php

<?php
namespace App\EventListener;

use App\Controller\DailyWinController;
use Psr\Log\LoggerInterface;
use Symfony\Component\HttpKernel\Event\FilterControllerEvent;

class ControllerListener implements DailyWinController
{
    public function onKernelController(FilterControllerEvent $event, LoggerInterface $logger) {
        $logger->alert('Working');
    }
}

~/src/Controller/DailyWinController.php

<?php
namespace App\Controller;

interface DailyWinController {
    // maybe there something?
}

~/src/Controller/UserController.php

<?php
namespace App\Controller;

use App\Entity\User;
use App\Entity\DailyWin;
use Psr\Log\LoggerInterface;
use Symfony\Component\Routing\Annotation\Route;
use Symfony\Component\Security\Core\User\UserInterface;
use Symfony\Bundle\FrameworkBundle\Controller\Controller;
use Symfony\Component\Security\Core\Authorization\AuthorizationCheckerInterface;

class UserController extends Controller implements DailyWinController
{
    /**
     * @Route("/user", name="user")
     * @param AuthorizationCheckerInterface $authChecker
     * @param UserInterface $user
     * @return \Symfony\Component\HttpFoundation\RedirectResponse|\Symfony\Component\HttpFoundation\Response
     */
    public function user(AuthorizationCheckerInterface $authChecker, UserInterface $user = null, LoggerInterface $logger) {
        if ($authChecker->isGranted('ROLE_USER') === false) {
            return $this->redirectToRoute('logowanie');
        }

        $logger->warning('Logger is working');

        $em = $this->getDoctrine()->getManager();
        $DWrep = $em->getRepository(DailyWin::class);

        $userId = $user->getId();
        $dailyWin = $DWrep->findOneBy(['userId' => $userId]);

        return $this->render('andprize/user/index.html.twig', array(
            'dailyWin' => $dailyWin,
            'userId' => $userId
        ));
    }
}

I have the following problem:

FatalThrowableError Type error: Argument 2 passed to App\EventListener\ControllerListener::onKernelController() must implement interface Psr\Log\LoggerInterface, string given

  • 写回答

1条回答 默认 最新

  • drflkphi675447 2017-12-24 14:46
    关注

    You have to inject the logger to the listener.

    <?php
    namespace App\EventListener;
    
    use App\Controller\DailyWinController;
    use Psr\Log\LoggerInterface;
    use Symfony\Component\HttpKernel\Event\FilterControllerEvent;
    
    class ControllerListener implements DailyWinController
    {
        protected $logger;
        public function __construct(LoggerInterface $logger)
        {
            $this->logger=$logger;
        }
        public function onKernelController(FilterControllerEvent $event) {
            $this->logger->alert('Working');
        }
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 r语言神经网络自变量重要性分析
  • ¥15 基于双目测规则物体尺寸
  • ¥15 wegame打不开英雄联盟
  • ¥15 公司的电脑,win10系统自带远程协助,访问家里个人电脑,提示出现内部错误,各种常规的设置都已经尝试,感觉公司对此功能进行了限制(我们是集团公司)
  • ¥15 救!ENVI5.6深度学习初始化模型报错怎么办?
  • ¥30 eclipse开启服务后,网页无法打开
  • ¥30 雷达辐射源信号参考模型
  • ¥15 html+css+js如何实现这样子的效果?
  • ¥15 STM32单片机自主设计
  • ¥15 如何在node.js中或者java中给wav格式的音频编码成sil格式呢