Як діагностувати помилку "Недійсний тип блоку .."?


19

Не знаю, як з’ясувати цю помилку, я вже тиждень гуглю і не можу знайти рішення. Будь-які ідеї?

2013-06-10T04:04:28+00:00 ERR (3): 
exception 'Mage_Core_Exception' with message 'Invalid block type: ' in /home/xxxxxxx/public_html/app/Mage.php:594
Stack trace:
#0 /home/xxxxxxx/public_html/app/code/core/Mage/Core/Model/Layout.php(495): Mage::throwException('Invalid block t...')
#1 /home/xxxxxxx/public_html/app/code/core/Mage/Core/Model/Layout.php(437): Mage_Core_Model_Layout->_getBlockInstance('', Array)
#2 /home/xxxxxxx/public_html/app/code/core/Mage/Core/Model/Layout.php(472): Mage_Core_Model_Layout->createBlock('', 'checkout.cart')
#3 /home/xxxxxxx/public_html/app/code/core/Mage/Core/Model/Layout.php(239): Mage_Core_Model_Layout->addBlock('', 'checkout.cart')
#4 /home/xxxxxxx/public_html/app/code/core/Mage/Core/Model/Layout.php(205): Mage_Core_Model_Layout->_generateBlock(Object(Mage_Core_Model_Layout_Element), Object(Mage_Core_Model_Layout_Element))
#5 /home/xxxxxxx/public_html/app/code/core/Mage/Core/Model/Layout.php(210): Mage_Core_Model_Layout->generateBlocks(Object(Mage_Core_Model_Layout_Element))
#6 /home/xxxxxxx/public_html/app/code/core/Mage/Core/Controller/Varien/Action.php(344): Mage_Core_Model_Layout->generateBlocks()
#7 /home/xxxxxxx/public_html/app/code/core/Mage/Core/Controller/Varien/Action.php(269): Mage_Core_Controller_Varien_Action->generateLayoutBlocks()
#8 /home/xxxxxxx/public_html/app/code/core/Mage/Checkout/controllers/CartController.php(159): Mage_Core_Controller_Varien_Action->loadLayout()
#9 /home/xxxxxxx/public_html/app/code/core/Mage/Core/Controller/Varien/Action.php(419): Mage_Checkout_CartController->indexAction()
#10 /home/xxxxxxx/public_html/app/code/core/Mage/Core/Controller/Varien/Router/Standard.php(250): Mage_Core_Controller_Varien_Action->dispatch('index')
#11 /home/xxxxxxx/public_html/app/code/core/Mage/Core/Controller/Varien/Front.php(176): Mage_Core_Controller_Varien_Router_Standard->match(Object(Mage_Core_Controller_Request_Http))
#12 /home/xxxxxxx/public_html/app/code/core/Mage/Core/Model/App.php(354): Mage_Core_Controller_Varien_Front->dispatch()
#13 /home/xxxxxxx/public_html/app/Mage.php(683): Mage_Core_Model_App->run(Array)
#14 /home/xxxxxxx/public_html/index.php(89): Mage::run('', 'store')
#15 {main}

Відповіді:


20

Виходячи з опублікованого вами сліду стека, схоже, що це відбувається, коли Magento завантажує файли оновлення xml-файлів та використовує їх для створення блоків, які надаватимуть HTML для сторінки.

Ці рядки, здається, є проблемою

#1 /home/xxxxxxx/public_html/app/code/core/Mage/Core/Model/Layout.php(437): Mage_Core_Model_Layout->_getBlockInstance('', Array)
#2 /home/xxxxxxx/public_html/app/code/core/Mage/Core/Model/Layout.php(472): Mage_Core_Model_Layout->createBlock('', 'checkout.cart')
#3 /home/xxxxxxx/public_html/app/code/core/Mage/Core/Model/Layout.php(239): Mage_Core_Model_Layout->addBlock('', 'checkout.cart')

Усі addBlock, createBlockі _getBlockInstanceметоди очікують, що перший параметр буде рядком псевдоніма класу для блоку. Щось подібне checkout/cart. Однак у вашій системі цей рядок відсутній.

->addBlock('', 'checkout.cart')

Оскільки Magento настільки розширюється, це може виникнути безліч причин. Найпоширенішою причиною є те, що ваш catalog.xmlфайл змінено так, що це

<block type="checkout/cart" name="checkout.cart">

Відсутній його typeатрибут. Це може виглядати приблизно так

<block name="checkout.cart">

Або це може бути помилка друку

<block typeX="checkout/cart" name="checkout.cart">

Сподіваюся, що це допомагає. Якщо проблема виявляється чимось іншим, обов’язково поверніться та опублікуйте правильну відповідь.


5
швидше за все, це щось на зразок <block name="checkout.cart">замість <reference name="checkout.cart">. Я бачив це в кількох темах, які є в Інтернеті (безкоштовно або платно). Простий пошук у layoutпапці теми повинен підтвердити (або відхилити) цю теорію.
Маріус

2
Правильно, referenceтег не спричинив би такий стек викликів - createBlockвикликається, що означає його blockтег.
Алан Шторм

3

За допомогою коментарів з мого оригінального допису я зміг відстежити код, що ображає!

Ось фрагмент, який спричинив виняток:

<checkout_cart_index>
    <reference name="content">
        <block name="checkout.cart">            
            <!-- Add CMS Static Block -->
            <block type="cms/block" name="snippet.cart.bottom" as="snippet_cart_bottom">
                <action method="setBlockId"><block_id>snippet_cart_bottom</block_id></action>
            </block>

            <!-- Add CMS Static Block -->
            <block type="cms/block" name="snippet.cart.coupon.below" as="snippet_cart_coupon_below">
                <action method="setBlockId"><block_id>snippet_cart_coupon_below</block_id></action>
            </block>

            <!-- Add CMS Static Block -->
            <block type="cms/block" name="snippet.cart.empty.bottom" as="snippet_cart_empty_bottom">
                <action method="setBlockId"><block_id>snippet_cart_empty_bottom</block_id></action>
            </block>

            <!-- Add CMS Static Block -->
            <block type="cms/block" name="snippet.cart.list.below" as="snippet_cart_list_below">
                <action method="setBlockId"><block_id>snippet_cart_list_below</block_id></action>
            </block>
        </block>
    </reference>
</checkout_cart_index>

Переглянений код більше не спричиняє винятків:

<checkout_cart_index>
    <reference name="checkout.cart">        
            <!-- Add CMS Static Block -->
            <block type="cms/block" name="snippet.cart.bottom" as="snippet_cart_bottom">
                <action method="setBlockId"><block_id>snippet_cart_bottom</block_id></action>
            </block>

            <!-- Add CMS Static Block -->
            <block type="cms/block" name="snippet.cart.coupon.below" as="snippet_cart_coupon_below">
                <action method="setBlockId"><block_id>snippet_cart_coupon_below</block_id></action>
            </block>

            <!-- Add CMS Static Block -->
            <block type="cms/block" name="snippet.cart.empty.bottom" as="snippet_cart_empty_bottom">
                <action method="setBlockId"><block_id>snippet_cart_empty_bottom</block_id></action>
            </block>

            <!-- Add CMS Static Block -->
            <block type="cms/block" name="snippet.cart.list.below" as="snippet_cart_list_below">
                <action method="setBlockId"><block_id>snippet_cart_list_below</block_id></action>
            </block>            
    </reference>
</checkout_cart_index>

0

Мені вдалося вирішити свої проблеми просто простим старим видаленням блоків. Я зробив це:

Додавання рядка Mage::log($className . ' - ' $blockName, null, 'logfile.log');до функції "_generateBlock" у /app/code/core/Mage/Core/Model/Layout.php

Так:

$block = $this->addBlock($className, $blockName);
if (!$block) {
    Mage::log($className . ' - ' $blockName, null, 'logfile.log');
    return $this;
}

Потім я видалив блоки, додавши наступний рядок до файлу local.xml у моїй темі / макеті

<remove name="fb8cd356f514800e782dfca09d40465d"/>
<remove name="1f0592cf88e12e898c194d5d18250c51"/>
<remove name="downloads.product"/>

Сподіваюся, що це комусь допоможе. Не витримав усіх дерьма, записаних у моєму файлі exceptions.log.

ОНОВЛЕННЯ:

Я виявив, що використовуючи цей код безпосередньо перед "поверненням $ this" у функції _generateBlock в /app/code/core/Mage/Core/Model/Layout.php

if ($_SERVER['HTTP_X_FORWARDED_FOR'] == '00.00.00.00') {
    Mage::log(Zend_Debug::dump($parentBlock, null, false), null, 'export_all_xml.log');
}

очевидно, змініть "HTTP_X_FORWARDED_FOR" на "REMOTE_ADDR", якщо вам це теж потрібно.

ОНОВЛЕННЯ 2

Нарешті я виявив проблему неправильно зі своїм сайтом, додавши:

if ($_SERVER['HTTP_X_FORWARDED_FOR'] == '00.00.00.00') {
    Mage::setIsDeveloperMode(true);
}

трохи вище 'Mage:: у функції '_getBlockInstance' у файлі '/app/code/core/Mage/Core/Model/Layout.php'

Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.