Как проверить или оформить страницу успеха заказа?


114

Если я перезагружаю checkout/onepage/successстраницу, меня направляют в корзину.

Поэтому при отладке или стилизации страницы успеха заказа мне всегда нужно сделать новый заказ.

Как я могу сделать это более эффективно?


2
Этот вопрос создал различные ответы, которые все полны "победы". Любой посетитель здесь должен просмотреть все ответы.
Крис К

Ответы:


149

Вы можете временно взломать ядро ​​во время разработки:

В /app/code/core/Mage/Checkout/controllers/OnepageController.phpредактировании successAction().

Закомментируйте строку $session->clear();. Теперь вы можете сделать один заказ и обновлять страницу так часто, как захотите.

Если вы даже не хотите делать заказ в каждом браузере, например, при проведении кросс-браузерного тестирования, вы также можете просто каждый раз инициализировать сеанс.

Выберите идентификатор заказа и идентификатор цитаты из таблицы sales_flat_order(поля: entity_idи quote_id). Например через:

SELECT entity_id as order_id, quote_id 
  FROM sales_flat_order ORDER BY entity_id DESC LIMIT 1;

Затем измените начало функции следующим образом:

$session = $this->getOnepage()->getCheckout();

$session->setLastSuccessQuoteId(INSERT_QUOTE_ID);
$session->setLastQuoteId(INSERT_QUOTE_ID);
$session->setLastOrderId(INSERT_ORDER_ID);

и заменить INSERT_....идентификаторами.

Теперь вы всегда можете позвонить checkout/onepage/success

Пока вы на него, вы можете протестировать , failureAction()а также, в

/app/code/core/Mage/Checkout/controllers/OnepageController.php

Измененное действие будет выглядеть так

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

Теперь вы всегда можете позвонить checkout/onepage/failure


Исправляет ли это вашу проблему? Пожалуйста, отметьте это как решение.
Фабиан Блехшмидт

3
Я протестировал тестер Jirese Reitsma Yireo Checkout и этот метод. В то время как модуль является самым простым способом, я обнаружил, что он не на 100% совместим с нашей темой и модулем оплаты, что приводит к стилю, отличному от оригинальной страницы успеха. Хотя этот метод требовал модификации ядра, он работал как прелесть. Примечание: в ответе отсутствует файл, который нужно отредактировать, - /app/code/core/Mage/Checkout/controllers/OnepageController.php
Ottonet,

Для людей, которые хотели бы сделать то же самое в M2, вы можете прокомментировать строки с 19 по 22 в\vendor\magento\module-checkout\Controller\Onepage\Success.php
Dynomite

24

Вам нужно изменить successAction () в

/app/code/core/Mage/Checkout/controllers/OnepageController.php

Модифицированное действие, как это

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
Но тогда $lastOrderIdне определено, что приведет к уведомлению и может привести к побочным эффектам в шаблоне.
Алекс

1
Я добился успеха, просто закомментировав $ session-> clear (); Единственное, что я теряю, это любые добавленные уведомления / сообщения, такие как TBT / Уведомления о вознаграждениях / Сообщения, добавленные через наблюдателя. Оставить код в модуле переопределения, который .gitignored, поэтому никогда не развертывается.
Барри Карлайон

19

Надеюсь, я не слишком саморекламируюсь, но я создал бесплатное расширение, которое можно быстро установить в Magento и которое позволяет предварительно просмотреть страницу успеха заказа для любого заказа - просто перейдя по URL-адресу: http: // www. yireo.com/software/magento-extensions/checkout-tester


4

Я думаю, что лучше просто прокомментировать $ session-> clear (); и добавлять продукты вручную, это работало для меня, но комментирование всего действия дало мне синтаксические ошибки.


4

Для Magento 2:

Если вы хотите стилизовать или настроить страницу успеха после успешной заявки, страница перенаправляется на страницу корзины.

Теперь решение здесь:

Перейти, чтобы vendor/magento/module-checkout/Controller/Onepage открыть Success.phpфайл.

В этом файле вы видите ниже код

 if (!$this->_objectManager->get('Magento\Checkout\Model\Session\SuccessValidator')->isValid()) {
     return $this->resultRedirectFactory->create()->setPath('checkout/cart');
 }

Просто прокомментируйте этот код, и ваша проблема решена. После комментария вы не будете перенаправлены на страницу корзины.


3

Вместо того, чтобы отправлять электронные письма из локальной копии / копии для разработки, вы можете записать содержимое электронной почты в файл, а затем просто посмотреть локально, что, на мой взгляд, будет очень удобно. Вот как это может быть достигнуто. Сначала все письма отправляются с

Mage_Core_Model_Email_Template::send($email, $name = null, array $variables = array())

Найдите это и добавьте следующие строки.

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

После этого после создания любого заказа в корне документа Magento будет создан email.html, который вы можете открыть в браузере, чтобы увидеть результат.

Далее, для отправки / повторной отправки любых электронных писем с заказами вы можете просто войти в систему администратора, и для каждого заказа есть кнопка «Отправить электронную почту», которая запустит этот сценарий, и вы увидите новый измененный шаблон, записанный в том же файле. Я думаю, что это один из лучших способов увидеть заказ или любые другие электронные письма.

Обратите внимание, чтобы удалить добавленный код, когда вы закончите.


1

Вы должны обновить код:

/app/code/core/Mage/Checkout/controllers/OnepageController.php

Функция обновления:

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

Просто прокомментируйте:

//$session->clear();

1

Magento 2

Как отмечает другой ответ, вы можете закомментировать перенаправление Magento\Checkout\Controller\Onepage\Success::executeи принудительно загрузить страницу успеха оформления заказа. Но когда блок, Magento\Checkout\Block\Onepage\Successзагружает, никакие данные заказа не будут присутствовать, потому Magento\Checkout\Model\Session::getLastRealOrderчто не будет возвращать заказ. Лучшим вариантом будет перехватчик после метода execute класса контроллера, где вы можете установить значение lastRealOrderIdв сеансе проверки.

Этот подход также дает возможность отправить checkout_onepage_controller_success_actionсобытие с желаемым вами заказом. Событие вызовет наблюдателей Magento\GoogleAdwords\Observer\SetConversionValueObserverи Magento\GoogleAnalytics\Observer\SetGoogleAnalyticsOnOrderSuccessPageViewObserverваши тестовые данные.

Следующее является довольно простым модулем, создающим перехватчик, описанный выше, и позволяет устанавливать порядок, добавляя orderпараметр запроса с желаемым идентификатором приращения к URL-адресу страницы успеха. В настоящее время это не сработает на маршруте успеха с мультидоставкой. Его можно скачать на github: https://github.com/pmclain/magento2-successtest

Приложение / код / ​​Pmclain / SuccessTest / и т.д. / интерфейс / 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>

Приложение / код / ​​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 Ниже добавлены параметры панели администратора для включения / отключения перехватчика.

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

Приложение / код / ​​Pmclain / SuccessTest / и т.д. / 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>

Приложение / код / ​​Pmclain / SuccessTest / и т.д. / 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>

Приложение / код / ​​Pmclain / SuccessTest / resgistration.php

<?php
\Magento\Framework\Component\ComponentRegistrar::register(
  \Magento\Framework\Component\ComponentRegistrar::MODULE,
  'Pmclain_SuccessTest',
  __DIR__
);
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.