Корзина Joomla 3.3 не опустошается после покупки при включенном sef, может кто-нибудь проверить мой файл маршрутизатора, пожалуйста?

#php #joomla #joomla-sef-urls

#php #joomla #joomla-sef-urls

Вопрос:

У меня возникла проблема с тем, что моя корзина Joomla 3 mijoshop не опорожняется после покупок, когда включен SEF, если я отключу SEF, она будет работать нормально. После некоторых поисков я полагаю, что это может быть проблема с тележками router.php файл, поэтому мне было интересно, может ли кто-нибудь помочь мне с этим. Я вставил свой текущий router.php код файлов приведен ниже.

 defined('_JEXEC') or die ('Restricted access');

require_once(JPATH_ROOT . '/components/com_mijoshop/mijoshop/mijoshop.php');

if (!class_exists('MiwisoftComponentRouterBase')) {
if (class_exists('JComponentRouterBase')) {
    abstract class MiwisoftComponentRouterBase extends JComponentRouterBase {}
}
else {
    class MiwisoftComponentRouterBase {}
}
}

class MijoShopRouter extends MiwisoftComponentRouterBase
{

static $cats = array();
static $path = array();

public function build(amp;$query) {
    return $this->buildRoute($query);
}

public function parse(amp;$segments) {
    return $this->parseRoute($segments);
}

public function buildRoute(amp;$query)
{
    $Itemid = null;
    $segments = array();

    $menu = $this->getMenu();

    $_get_itemid = 0;
    if($menu->getActive()){
        $_get_itemid = $menu->getActive()->id;
    }
    $_get_route = JRequest::getVar('route', '');

    if( isset($query['Itemid']) and $_get_itemid != $query['Itemid'] and $_get_route == 'product/category' and isset($query['route']) and $query['route'] == 'product/product' ){
        $query['Itemid'] = $_get_itemid;
    }

    if (!empty($query['Itemid'])) {
        $Itemid = $query['Itemid'];
    } else {
        $Itemid = $this->getItemid();
    }

    if (empty($Itemid)) {
        $a_menu = $menu->getActive();
    } else {
        $a_menu = $menu->getItem($Itemid);
    }

    if (isset($query['view'])) {
        if ($query['view'] == 'admin') {
            unset($query['view']);

            return $segments;
        }
        $_route = $this->getRoute($query['view'], false);
        if (!empty($_route)) {
            $query['route'] = $_route;
            unset($query['view']);
        }
        else {
            $segments[] = $query['view'];
            unset($query['view']);
        }
    }

    if (isset($query['route'])) {
        switch ($query['route']) {
            case 'product/product':
                if (is_object($a_menu) and $a_menu->query['view'] == 'product' and $a_menu->query['product_id'] == @$query['product_id']) {
                    unset($query['path']);
                    unset($query['product_id']);
                    unset($query['manufacturer_id']);
                    break;
                }

                $segments[] = 'product';

                if (isset($query['product_id'])) {
                    $id = $query['product_id'];
                    $name = MijoShop::get('db')->getRecordAlias($id);

                    if (!empty($name)) {
                        $segments[] = $id . ':' . $name;
                    } else {
                        $segments[] = $id;
                    }

                    unset($query['path']);
                    unset($query['product_id']);
                    unset($query['manufacturer_id']);
                    unset($query['sort']);
                    unset($query['order']);
                    unset($query['filter_name']);
                    unset($query['filter_tag']);
                    unset($query['limit']);
                    unset($query['page']);

                }

                break;
            case 'product/category':
                $_path = explode('_', @$query['path']);
                $m_id = end($_path);

                if (is_object($a_menu) and $a_menu->query['view'] == 'category' and $a_menu->query['path'] == $m_id) {
                    unset($query['path']);
                    break;
                }

                $segments[] = 'category';

                if (isset($query['path'])) {
                    $id = $query['path'];

                    if (strpos($id, '_')) {
                        $old_id = $id;
                        $_id = explode('_', $id);
                        $id = end($_id);

                        self::$cats[$id] = $old_id;
                    } else {
                        self::$cats[$id] = $id;
                    }

                    $name = MijoShop::get('db')->getRecordAlias($id, 'category');

                    if (!empty($name)) {
                        $segments[] = $id . ':' . $name;
                    } else {
                        $segments[] = $id;
                    }

                    unset($query['path']);
                }

                break;
            case 'product/manufacturer/info':
                if (is_object($a_menu) and $a_menu->query['view'] == 'manufacturer' and $a_menu->query['manufacturer_id'] == @$query['manufacturer_id']) {
                    unset($query['manufacturer_id']);
                    break;
                }

                $segments[] = 'manufacturer';

                if (isset($query['manufacturer_id'])) {
                    $id = $query['manufacturer_id'];
                    $name = MijoShop::get('db')->getRecordAlias($id, 'manufacturer');

                    if (!empty($name)) {
                        $segments[] = $id . ':' . $name;
                    } else {
                        $segments[] = $id;
                    }

                    unset($query['manufacturer_id']);
                }

                break;
            case 'information/information':
                if (is_object($a_menu) and $a_menu->query['view'] == 'information' and $a_menu->query['information_id'] == @$query['information_id']) {
                    unset($query['information_id']);
                    break;
                }

                $segments[] = 'information';

                if (isset($query['information_id'])) {
                    $id = $query['information_id'];
                    $name = MijoShop::get('db')->getRecordAlias($id, 'information');

                    if (!empty($name)) {
                        $segments[] = $id . ':' . $name;
                    } else {
                        $segments[] = $id;
                    }

                    unset($query['information_id']);
                }
 

Заранее спасибо всем, кто может помочь 🙂

Комментарии:

1. Mijoshop — это коммерческое расширение, поэтому вам следует связаться с разработчиком

2. Я уже связался со службой поддержки mijoshop, но их поддержка не кажется отличной. Они закрыли мой билет без решения, и прошло уже больше недели без каких-либо признаков какого-либо исправления, так что я подумал, что поищу в другом месте. В любом случае спасибо

3. Вау, это на самом деле плохо.


Ответ №1:

Эта проблема не имеет ничего общего с вашим router.php файл, это имеет отношение к процессу оформления заказа, поскольку эти товары в корзине фактически хранятся в базе данных.

Когда вы добавляете товары в корзину, они добавляются в таблицу в базе данных, после оформления заказа ваши товары обычно добавляются в таблицу order_item, а таблица заказов заполняется информацией о вашем заказе, и корзина очищается.

Я бы проверил файлы контроллера / модели, чтобы увидеть, где находится код проверки — ошибка определенно есть.