Magento 2.1.2 Фабрика действий Rourter попадает в бесконечный цикл
Я работаю над разработкой модуля в magento2. Проблема заключается в маршрутизации, где маршрутизатор возвращает $ this-> actionFactory-> create ('Magento \ Framework \ App \ Action \ Forward'); не перенаправляет на мой модуль, контроллер и действие, указанное в коде; это исключение. Фронтальный контроллер достиг 100 итераций сопоставления маршрутизатора. Любая помощь будет высоко оценена. Заранее спасибо!
public function match(\Magento\Framework\App\RequestInterface $request)
{
$identifier = trim($request->getPathInfo(), '/');
$condition = new \Magento\Framework\DataObject(['identifier' => $identifier, 'continue' => true]);
$this->eventManager->dispatch(
'news_controller_router_match_before',
['router' => $this, 'condition' => $condition]
);
$identifier = $condition->getIdentifier();
if ($condition->getRedirectUrl()) {
$this->response->setRedirect($condition->getRedirectUrl());
$request->setDispatched(true);
return $this->actionFactory->create('Magento\Framework\App\Action\Redirect');
}
if (!$condition->getContinue()) {
return null;
}
/*for main page */
/*check identifier against news-configuration main page idendifier */
//$mainIdentifier = $topic->getMainPageIdentifer();
$mainIdentifier = 'news';
if ($mainIdentifier == $identifier) {
$request->setModuleName('news')->setControllerName('index')->setActionName('view');
$request->setAlias(\Magento\Framework\Url::REWRITE_REQUEST_PATH_ALIAS, $identifier);
return $this->actionFactory->create('Magento\Framework\App\Action\Forward');
}
}
1 исключение (я): Исключение #0 (LogicException): Фронтальный контроллер достиг 100 итераций сопоставления маршрутизатора. Исключение #0 (LogicException): Фронтальный контроллер достиг 100 итераций сопоставления маршрутизатора #0 /opt/lampp/htdocs/Magento-CE-2.1.2_sample/vendor/magento/framework/Interception/Interceptor.php(74): Magento\Framework\App\FrontController->dispatch(Объект (Magento\Framework\App\Request\Http)) #1 /opt/lampp/htdocs/Magento-CE-2.1.2_sample/vendor/magento/framework/Interception/Chain/Chain.php(70): Magento\Framework\App\FrontController\Interceptor->___callParent('dispatch', Array) #2 /opt/lampp/htdocs/Magento-CE-2.1.2_sample/vendor/magento/framework/Interception/Chain/Chain.php(63): Magento\Framework\Interception\Chain\Chain->invokeNext('Magento\\Framewo...', 'dispatch', Object(Magento\Framework\App\FrontController\Interceptor), Array, 'requestPreproce...') #3 /opt/lampp/htdocs/Magento-CE-2.1.2_sample/vendor/magento/module-store/App/FrontController/Plugin/RequestPreprocessor.php(94): Magento\Framework\Interception\Chain\Chain->Magento\Framework\Interception\Chain\{closure}(Объект (Magento\Framework\App\Request\Http)) #4 /opt/lampp/htdocs/Magento-CE-2.1.2_sample/vendor/magento/framework/Interception/Chain/Chain.php(67): Magento\Store\App\FrontController\Plugin\RequestPreprocessor->aroundDispatch(Объект (Magento \ Framework \ App \ FrontController \ Interceptor), Объект (Закрытие), Объект (Magento\Framework\App\Request\Http)) #5 /opt/lampp/htdocs/Magento-CE-2.1.2_sample/vendor/magento/framework/Interception/Chain/Chain.php(63): Magento\Framework\Interception\Chain\Chain->invokeNext('Magento\\Framewo...', 'dispatch', Object(Magento\Framework\App\FrontController\Interceptor), Массив, 'install') #6 /opt/lampp/htdocs/Magento-CE-2.1.2_sample/vendor/magento/framework/Module/Plugin/DbStatusValidator.php(69): Magento\Framework\Interception\Chain-> Chain-> Magento \ Framework \ Interception \ Chain \ {closure} (объект (Magento\Framework\App\Request\Http)) #7 /opt/lampp/htdocs/Magento-CE-2.1.2_sample/vendor/magento/framework/Interception/Chain/Chain.php(67): Magento\Framework\Module\Plugin\DbStatusValidator->aroundDispatch(Объект (Magento \ Framework \ App \ FrontController \ Interceptor), Объект (Закрытие), Объект (Magento\Framework\App\Request\Http)) #8 /opt/lampp/htdocs/Magento-CE-2.1.2_sample/vendor/magento/framework/Interception/Chain/Chain.php(63): Magento\Framework\Interception\Chain\Chain->invokeNext('Magento\\Framewo...', 'dispatch', Object(Magento\Framework\App\FrontController\Interceptor), массив, 'front-controlle...') #9 /opt/lampp/htdocs/Magento-CE-2.1.2_sample/vendor/magento/module-page-cache/Model/App/FrontController/VarnishPlugin.php(55): Magento\Framework\Interception\Chain\Chain->Magento\Framework\Interception\Chain\{closure}(Object(Magento\Framework\App\Request\Http)) #10 /opt/lampp/htdocs/Magento-CE-2.1.2_sample/vendor/magento/framework/Interception/Chain/Chain.php(67): Magento\PageCache\Model\App\FrontController\VarnishPlugin->aroundDispatch(Объект (Magento \ Framework \ App \ FrontController \ Intercepto) r), Object(Закрытие), Object(Magento\Framework\App\Request\Http)) #11 /opt/lampp/htdocs/Magento-CE-2.1.2_sample/vendor/magento/framework/Interception/Interceptor.php(138): Magento\Framework\Interception\Chain\Chain->invokeNext('Magento\\Framewo...', 'dispatch', Object(Magento\Framework\App\FrontController\Interceptor), Array, 'front-controlle...') #12 /opt/lampp/htdocs/Magento-CE-2.1.2_sample/vendor/magento/module-page-cache/Model/App/FrontController/BuiltinPlugin.php(68): Magento\Framework\App\FrontController\Interceptor->Magento\Framework\Interception\{closure}(Объект (Magento\Framework\App\Request\Http)) #13 /opt/lampp/htdocs/Magento-CE-2.1.2_sample/vendor/magento/framework/Interception/Interceptor.php(142): Magento\PageCache\Model\App\FrontController\BuiltinPlugin->aroundDispatch(Объект (Magento \ Framework \ App \ FrontController \ Interceptor), Объект (Закрытие), Объект (Magento\Framework\App\Request\Http)) #14 /opt/lampp/htdocs/Magento-CE-2.1.2_sample/var/generation/Magento/Framework/App/FrontController/Interceptor.php(26): Magento\Framework\App\FrontController\Interceptor->___callPlugins('dispatch', Array, Array) #15 /opt/lampp/htdocs/Magento-CE-2.1.2_sample/vendor/magento/framework/App/Http.php(135): Magento\Framework\App\FrontController\Interceptor->dispatch(Объект (Magento\Framework\App\Request\Http)) #16 /opt/lampp/htdocs/Magento-CE-2.1.2_sample/vendor/magento/framework/App/Bootstrap.php(258): Magento\Framework\App\Http->launch() #17 /opt/lampp/htdocs/Magento-CE-2.1.2_sample/index.php(39): Magento\Framework\App\Bootstrap->run(Объект (Magento\Framework\App\Http)) #18 {main}
2 ответа
Решение
Наконец, я решил проблему, это было связано с сортировкой в etc frontend di.xml <item name="sortOrder" xsi:type="string">20</item>
Я изменил 20 на 60, и ошибка исчезла.
Моя проблема была такой же, как ваша, пожалуйста, обновите ваш файл etc/frontend/di.xml следующим образом:
<item name="sortOrder" xsi:type="string">60</item>