Jeśli ponownie załaduję checkout/onepage/success
stronę, nastąpi przekierowanie do koszyka.
Tak więc, podczas debugowania lub stylizacji strony sukcesu zamówienia, zawsze muszę złożyć nowe zamówienie.
Jak mogę to zrobić bardziej efektywnie?
Jeśli ponownie załaduję checkout/onepage/success
stronę, nastąpi przekierowanie do koszyka.
Tak więc, podczas debugowania lub stylizacji strony sukcesu zamówienia, zawsze muszę złożyć nowe zamówienie.
Jak mogę to zrobić bardziej efektywnie?
Odpowiedzi:
Możesz tymczasowo zhakować rdzeń podczas opracowywania:
W /app/code/core/Mage/Checkout/controllers/OnepageController.php
edycji successAction()
.
Skomentuj linię $session->clear();
. Teraz możesz złożyć jedno zamówienie i odświeżać stronę tak często, jak chcesz.
Jeśli nawet nie chcesz składać zamówienia w każdej przeglądarce, na przykład podczas testowania w różnych przeglądarkach, możesz po prostu zainicjować sesję za każdym razem.
Wybierz identyfikator zamówienia i identyfikator oferty z tabeli sales_flat_order
(pola: entity_id
i quote_id
). Na przykład przez:
SELECT entity_id as order_id, quote_id
FROM sales_flat_order ORDER BY entity_id DESC LIMIT 1;
Następnie zmień początek funkcji w następujący sposób:
$session = $this->getOnepage()->getCheckout();
$session->setLastSuccessQuoteId(INSERT_QUOTE_ID);
$session->setLastQuoteId(INSERT_QUOTE_ID);
$session->setLastOrderId(INSERT_ORDER_ID);
i zamień INSERT_....
na identyfikatory.
Teraz możesz zawsze zadzwonić checkout/onepage/success
W tym momencie możesz również przetestować failureAction()
, w
/app/code/core/Mage/Checkout/controllers/OnepageController.php
Zmodyfikowana akcja wyglądałaby tak
public function failureAction()
{
$session = $this->getOnepage()->getCheckout();
$session->setLastSuccessQuoteId(INSERT_QUOTE_ID);
$session->setLastQuoteId(INSERT_QUOTE_ID);
$session->setLastOrderId(INSERT_ORDER_ID);
$lastQuoteId = $this->getOnepage()->getCheckout()->getLastQuoteId();
$lastOrderId = $this->getOnepage()->getCheckout()->getLastOrderId();
if (!$lastQuoteId || !$lastOrderId) {
$this->_redirect('checkout/cart');
return;
}
$this->loadLayout();
$this->renderLayout();
}
Teraz możesz zawsze zadzwonić checkout/onepage/failure
\vendor\magento\module-checkout\Controller\Onepage\Success.php
Musisz zmodyfikować SuccessAction () w
/app/code/core/Mage/Checkout/controllers/OnepageController.php
Zmodyfikowane działanie chciałoby to
public function successAction()
{
/*
$session = $this->getOnepage()->getCheckout();
if (!$session->getLastSuccessQuoteId()) {
$this->_redirect('checkout/cart');
return;
}
$lastQuoteId = $session->getLastQuoteId();
$lastOrderId = $session->getLastOrderId();
$lastRecurringProfiles = $session->getLastRecurringProfileIds();
if (!$lastQuoteId || (!$lastOrderId && empty($lastRecurringProfiles))) {
$this->_redirect('checkout/cart');
return;
}
$session->clear();
*/
$this->loadLayout();
$this->_initLayoutMessages('checkout/session');
Mage::dispatchEvent('checkout_onepage_controller_success_action', array('order_ids' => array($lastOrderId)));
$this->renderLayout();
}
$lastOrderId
nie jest zdefiniowane, co mogłoby wpłynąć na powiadomienie i może prowadzić do skutków ubocznych w szablonie.
Mam nadzieję, że nie promuję się zbytnio, ale stworzyłem bezpłatne rozszerzenie, które można szybko zainstalować w Magento i pozwala wyświetlić podgląd strony sukcesu zamówienia dla dowolnego zamówienia - po prostu uzyskując dostęp do adresu URL: http: // www. yireo.com/software/magento-extensions/checkout-tester
Myślę, że lepiej jest po prostu skomentować $ session-> clear (); i ręcznie dodawać produkty, które działały dla mnie, ale komentowanie całej akcji spowodowało błędy składniowe.
W przypadku Magento 2:
Jeśli chcesz stylizować lub dostosować stronę sukcesu po zamówieniu strona przekierowuje do strony koszyka.
Teraz rozwiązanie jest tutaj:
Idź, aby vendor/magento/module-checkout/Controller/Onepage
otworzyć Success.php
plik.
W tym pliku widać kod poniżej
if (!$this->_objectManager->get('Magento\Checkout\Model\Session\SuccessValidator')->isValid()) {
return $this->resultRedirectFactory->create()->setPath('checkout/cart');
}
Po prostu skomentuj ten kod, a Twój problem zostanie rozwiązany. Po skomentowaniu nie przekierowujesz na stronę koszyka.
Zamiast wysyłać wiadomości e-mail z kopii lokalnej / programistycznej, możesz zrzucić zawartość wiadomości e-mail do pliku, a następnie po prostu zobaczyć lokalnie, co moim zdaniem będzie bardzo przydatne. Oto jak można to osiągnąć. Najpierw wysyłane są wszystkie wiadomości e-mail
Mage_Core_Model_Email_Template::send($email, $name = null, array $variables = array())
Znajdź to i dodaj następujące wiersze.
$this->setUseAbsoluteLinks(true);
$text = $this->getProcessedTemplate($variables, true);
if($this->isPlain()) {
$mail->setBodyText($text);
} else {
$mail->setBodyHTML($text);
}
// Added Code //
$filePath = Mage::getBaseDir() . DS . 'email.html';
Mage::log($filePath);
file_put_contents($filePath, $text);
// Added Code Ends //
$mail->setSubject('=?utf-8?B?' . base64_encode($this->getProcessedTemplateSubject($variables)) . '?=');
$mail->setFrom($this->getSenderEmail(), $this->getSenderName());
Po utworzeniu dowolnego zamówienia w katalogu głównym dokumentu Magento zostanie utworzony plik email.html, który można otworzyć w przeglądarce, aby wyświetlić dane wyjściowe.
Następnie, aby wysłać / ponownie wysłać dowolne wiadomości e-mail z zamówieniem, wystarczy zalogować się do administratora, a dla każdego zamówienia jest przycisk Wyślij e-mail, który uruchomi ten skrypt, i zobaczysz nowo zmieniony szablon zapisany w tym samym pliku. Myślę, że jest to jeden z najlepszych sposobów, aby zobaczyć zamówienie lub inne wiadomości e-mail.
Pamiętaj, aby po zakończeniu usunąć dodany kod.
Musisz zaktualizować kod:
/app/code/core/Mage/Checkout/controllers/OnepageController.php
Funkcja aktualizacji:
public function successAction()
{
$session = $this->getOnepage()->getCheckout();
if (!$session->getLastSuccessQuoteId()) {
$this->_redirect('checkout/cart');
return;
}
$lastQuoteId = $session->getLastQuoteId();
$lastOrderId = $session->getLastOrderId();
$lastRecurringProfiles = $session->getLastRecurringProfileIds();
if (!$lastQuoteId || (!$lastOrderId && empty($lastRecurringProfiles))) {
$this->_redirect('checkout/cart');
return;
}
//$session->clear();
$this->loadLayout();
$this->_initLayoutMessages('checkout/session');
Mage::dispatchEvent('checkout_onepage_controller_success_action', array('order_ids' => array($lastOrderId)));
$this->renderLayout();
}
Po prostu skomentuj:
//$session->clear();
Jak zauważa kolejna odpowiedź, możesz skomentować przekierowanie Magento\Checkout\Controller\Onepage\Success::execute
i wymusić załadowanie strony powodzenia kasy. Ale gdy blok, Magento\Checkout\Block\Onepage\Success
ładuje, dane zamówienia nie będą obecne, ponieważ Magento\Checkout\Model\Session::getLastRealOrder
nie zwróci zamówienia. Lepszym rozwiązaniem byłoby przechwytywanie po metodzie wykonawczej klasy kontrolera, w której można ustawić wartość dla lastRealOrderId
sesji pobierania.
Takie podejście zapewnia również możliwość wysłania checkout_onepage_controller_success_action
zdarzenia z żądanym zamówieniem. Zdarzenie wyzwoli obserwatorów Magento\GoogleAdwords\Observer\SetConversionValueObserver
i Magento\GoogleAnalytics\Observer\SetGoogleAnalyticsOnOrderSuccessPageViewObserver
dane testowe.
Poniżej znajduje się dość podstawowy moduł tworzący przechwytywacz opisany powyżej i umożliwia ustawienie kolejności poprzez dodanie order
parametru zapytania o pożądanym identyfikatorze wzrostu do adresu URL strony sukcesu. Obecnie nie będzie działać na drodze do sukcesu multishipping. Można go pobrać na github: https://github.com/pmclain/magento2-successtest
app / code / Pmclain / SuccessTest / etc / frontend / di.xml
<?xml version="1.0"?>
<config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="urn:magento:framework:ObjectManager/etc/config.xsd">
<type name="Magento\Checkout\Controller\Onepage\Success">
<plugin name="pmclain_successtest_checkout_controller_onepage_success"
type="Pmclain\SuccessTest\Plugin\Success"
sortOrder="10" />
</type>
</config>
app / code / Pmclain / SuccessTest / Plugin / Success.php
<?php
namespace Pmclain\SuccessTest\Plugin;
use Magento\Framework\Event\ManagerInterface;
use Magento\Framework\View\Result\PageFactory;
use Magento\Framework\App\Config\ScopeConfigInterface;
use Magento\Store\Model\ScopeInterface;
use Magento\Checkout\Model\Session;
use Magento\Sales\Model\OrderFactory;
use Magento\Sales\Model\Order;
class Success
{
/** @var ManagerInterface */
protected $_eventManager;
/** @var PageFactory */
protected $_resultPageFactory;
/** @var ScopeConfigInterface */
protected $_scopeConfig;
/** @var OrderFactory */
protected $_orderFactory;
/** @var Order */
protected $_order;
/** @var Session */
protected $_checkoutSession;
/**
* Success constructor.
* @param ManagerInterface $eventManager
* @param PageFactory $resultPageFactory
* @param ScopeConfigInterface $scopeConfig
* @param OrderFactory $orderFactory
* @param Session $session
*/
public function __construct(
ManagerInterface $eventManager,
PageFactory $resultPageFactory,
ScopeConfigInterface $scopeConfig,
OrderFactory $orderFactory,
Session $session
) {
$this->_eventManager = $eventManager;
$this->_resultPageFactory = $resultPageFactory;
$this->_scopeConfig = $scopeConfig;
$this->_orderFactory = $orderFactory;
$this->_checkoutSession = $session;
}
/**
* @param \Magento\Checkout\Controller\Onepage\Success $subject
* @param $result
* @return \Magento\Framework\View\Result\Page
*/
public function afterExecute(\Magento\Checkout\Controller\Onepage\Success $subject, $result)
{
if (!$this->_isEnabled()) {
return $result;
}
$order = $this->_getTestOrder($subject->getRequest()->getParam('order'));
if (!$order->getId()) {
return $result;
}
$this->_checkoutSession->setLastRealOrderId($order->getIncrementId());
$resultPage = $this->_resultPageFactory->create();
$this->_eventManager->dispatch(
'checkout_onepage_controller_success_action',
['order_ids' => [$order->getId()]]
);
return $resultPage;
}
/**
* @return bool
*/
protected function _isEnabled()
{
if ($this->_scopeConfig->getValue('dev/debug/success_test', ScopeInterface::SCOPE_STORE)) {
return true;
}
return false;
}
/**
* @param $incrementId string|bool
* @return Order
*/
protected function _getTestOrder($incrementId)
{
/** @var Order $order */
$order = $this->_orderFactory->create();
$order->loadByIncrementId($incrementId);
return $order;
}
}
app / code / Pmclain / SuccessTest / etc / adminhtml / system.xml Poniżej dodano opcje panelu administratora, aby włączyć / wyłączyć przechwytywacz.
<?xml version="1.0"?>
<config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="urn:magento:module:Magento_Config:etc/system_file.xsd">
<system>
<section id="dev">
<group id="debug">
<field id="success_test" translate="label" type="select" sortOrder="30" showInDefault="1" showInWebsite="1" showInStore="0">
<label>Enable Checkout Success Page Testing</label>
<source_model>Magento\Config\Model\Config\Source\Yesno</source_model>
</field>
</group>
</section>
</system>
</config>
app / code / Pmclain / SuccessTest / etc / config.xml
<?xml version="1.0"?>
<config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="urn:magento:module:Magento_Store:etc/config.xsd">
<default>
<dev>
<debug>
<success_test>0</success_test>
</debug>
</dev>
</default>
</config>
app / code / Pmclain / SuccessTest / etc / module.xml
<?xml version="1.0"?>
<config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="urn:magento:framework:Module/etc/module.xsd">
<module name="Pmclain_SuccessTest" setup_version="0.0.1">
<sequence>
<module name="Magento_Backend" />
<module name="Magento_Checkout" />
</sequence>
</module>
</config>
app / code / Pmclain / SuccessTest / resgistration.php
<?php
\Magento\Framework\Component\ComponentRegistrar::register(
\Magento\Framework\Component\ComponentRegistrar::MODULE,
'Pmclain_SuccessTest',
__DIR__
);