Jak zdiagnozować błąd „Nieprawidłowy typ bloku…”?

19

Nie jestem pewien, jak rozwiązać ten problem, googlowałem od tygodnia i nie mogę znaleźć rozwiązania. Jakieś pomysły?

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}
riskywebmaster
źródło

Odpowiedzi:

20

Na podstawie śladu stosu, który opublikowałeś, wygląda na to, że dzieje się tak, gdy Magento ładuje pliki XML aktualizacji układu i używa ich do tworzenia bloków, które renderują HTML strony.

Te linie wydają się stanowić problem

#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')

Te addBlock, createBlockoraz _getBlockInstancemetody wszyscy oczekują, że pierwszy parametr będzie ciąg klasa alias do bloku. Coś jak checkout/cart. Jednak w twoim systemie brakuje tego ciągu.

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

Ponieważ Magento jest tak rozbudowywalny, istnieje wiele powodów, dla których może się to zdarzyć. Najczęstszym powodem jest to, że Twój catalog.xmlplik został zmieniony w taki sposób, że to

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

Brakuje jego typeatrybutu. To może tak wyglądać

<block name="checkout.cart">

Lub może to być literówka

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

Mam nadzieję, że to pomaga. Jeśli problemem będzie coś innego, koniecznie wróć i opublikuj poprawną odpowiedź.

Alan Storm
źródło
5
najprawdopodobniej jest coś takiego <block name="checkout.cart">zamiast <reference name="checkout.cart">. Widziałem to w kilku tematach dostępnych w Internecie (za darmo lub za opłatą). Proste wyszukiwanie w layoutfolderze motywu powinno potwierdzić (lub odrzucić) tę teorię.
Marius
2
Tak, referenceznacznik nie spowodowałby wywołania stosu wywołań - createBlockjest wywoływany, co oznacza, że ​​jest to blockznacznik.
Alan Storm,
3

Dzięki komentarzom z mojego oryginalnego posta udało mi się wyśledzić kod, który go narusza!

Oto fragment kodu, który spowodował wyjątek:

<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>

Zmieniony kod nie powoduje już wyjątków:

<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>
riskywebmaster
źródło
0

Udało mi się rozwiązać moje problemy, po prostu usuwając bloki. Zrobiłem to przez:

Dodanie wiersza Mage::log($className . ' - ' $blockName, null, 'logfile.log');do funkcji „_generateBlock” w /app/code/core/Mage/Core/Model/Layout.php

Tak jak:

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

Następnie usunąłem bloki, dodając następujący wiersz do mojego pliku local.xml w moim kompozycji / układzie

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

Mam nadzieję, że to komuś pomoże. Nie mogłem znieść wszystkich bzdur zapisanych w moim pliku wyjątki.log.

AKTUALIZACJA:

Odkryłem, że użycie tego kodu tuż przed „return $ this” w funkcji _generateBlock w /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');
}

w razie potrzeby zmień oczywiście „HTTP_X_FORWARDED_FOR” na „REMOTE_ADDR”.

AKTUALIZACJA 2

Znalazłem problem z moją witryną, dodając:

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

tuż nad „Mage :: throwException (Mage :: helper ('core') -> __ ('Nieprawidłowy typ bloku:% s', $ block)); ' w funkcji „_getBlockInstance” w pliku „/app/code/core/Mage/Core/Model/Layout.php”

rupi
źródło