Jak przetestować lub stylizować stronę sukcesu zamówienia?


114

Jeśli ponownie załaduję checkout/onepage/successstronę, 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?


2
To pytanie stworzyło różnorodne odpowiedzi, które są pełne „wygranej”. Każdy, kto tu przyjedzie, powinien przejrzeć wszystkie odpowiedzi.
Chris K

Odpowiedzi:


149

Możesz tymczasowo zhakować rdzeń podczas opracowywania:

W /app/code/core/Mage/Checkout/controllers/OnepageController.phpedycji 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_idi 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


Naprawia to twój problem? Oznacz to jako rozwiązanie.
Fabian Blechschmidt,

3
Testowałem zarówno Yireo Checkout Tester Jisse Reitsma, jak i tę metodę. Chociaż moduł jest najłatwiejszy, okazało się, że nie jest w 100% zgodny z naszym modułem motywu i płatności, co skutkuje inną stylizacją niż oryginalna strona sukcesu. Metoda wymagająca modyfikacji rdzenia działała jednak jak urok. Uwaga: w odpowiedzi brakuje pliku, który należy edytować, a mianowicie /app/code/core/Mage/Checkout/controllers/OnepageController.php
Ottonet,

Dla osób, które chciałyby zrobić to samo w M2, możesz komentować wiersze od 19 do 22 w\vendor\magento\module-checkout\Controller\Onepage\Success.php
Dynomite

24

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();
    }

3
Ale wtedy $lastOrderIdnie jest zdefiniowane, co mogłoby wpłynąć na powiadomienie i może prowadzić do skutków ubocznych w szablonie.
Alex

1
Odniosłem sukces, komentując $ session-> clear (); Jedyne, co tracę, to wszelkie dodane powiadomienia / wiadomości, takie jak TBT / Powiadomienia o nagrodach / Wiadomości dodane za pośrednictwem obserwatora. Pozostawienie kodu w module zastępującym, który jest .gitignored, więc nigdy nie jest wdrażany.
Barry Carlyon


4

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.


4

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

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.


3

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.


1

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();

1

Magento 2

Jak zauważa kolejna odpowiedź, możesz skomentować przekierowanie Magento\Checkout\Controller\Onepage\Success::executei 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::getLastRealOrdernie zwróci zamówienia. Lepszym rozwiązaniem byłoby przechwytywanie po metodzie wykonawczej klasy kontrolera, w której można ustawić wartość dla lastRealOrderIdsesji pobierania.

Takie podejście zapewnia również możliwość wysłania checkout_onepage_controller_success_actionzdarzenia z żądanym zamówieniem. Zdarzenie wyzwoli obserwatorów Magento\GoogleAdwords\Observer\SetConversionValueObserveri Magento\GoogleAnalytics\Observer\SetGoogleAnalyticsOnOrderSuccessPageViewObserverdane testowe.

Poniżej znajduje się dość podstawowy moduł tworzący przechwytywacz opisany powyżej i umożliwia ustawienie kolejności poprzez dodanie orderparametru 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__
);
Korzystając z naszej strony potwierdzasz, że przeczytałeś(-aś) i rozumiesz nasze zasady używania plików cookie i zasady ochrony prywatności.
Licensed under cc by-sa 3.0 with attribution required.