Как в OpenCart удалить index.php?route= из всех ссылок?

Практика



/* Как в OpenCart удалить index.php?route= из всех ссылок?
в файле /catalog/controller/common/seo_url.php
сделайте такие изменения (выделено жирным)
*/
class ControllerCommonSeoUrl extends Controller
{


     //****
    {

        if (isset($this->request->get['product_id']))
        {
            $this->request->get['route'] = 'product/product';
        } elseif (isset($this->request->get['path']))
        {
            $this->request->get['route'] = 'product/category';
        } elseif (isset($this->request->get['manufacturer_id']))
        {
            $this->request->get['route'] = 'product/manufacturer/info';
        } elseif (isset($this->request->get['information_id']))
        {
            $this->request->get['route'] = 'information/information';
        } else
        {
            $this->request->get['route'] = $this->request->get['_route_'];
        }

        if (isset($this->request->get['route']))
        {
            return $this->forward($this->request->get['route']);
        }
    }

    public function rewrite($link)
    {
        if ($this->config->get('config_seo_url'))
        {
            $url_data = parse_url(str_replace('&', '&', $link));
            $url = '';

            $data = array();

            parse_str($url_data['query'], $data);
            foreach ($data as $key => $value)
            {

                if (isset($data['route']))
                {
                    if (($data['route'] == 'product/product' && $key == 'product_id') || (($data['route'] ==
                        'product/manufacturer/info' || $data['route'] == 'product/product') && $key ==
                        'manufacturer_id') || ($data['route'] == 'information/information' && $key ==
                        'information_id'))
                    {
                        $query = $this->db->query('SELECT * FROM ' . DB_PREFIX .
                            'url_alias WHERE `query` = ' . $this->db->escape($key . '=' . (int)$value));

                        if ($query->num_rows)
                        {
                            $url .= '/' . $query->row['keyword'];

                            unset($data[$key]);
                        }
                    } elseif ($key == 'path')
                    {
                        $categories = explode('_', $value);

                        foreach ($categories as $category)
                        {
                            $query = $this->db->query('SELECT * FROM ' . DB_PREFIX .
                                'url_alias WHERE `query` = 'category_id=' . (int)$category . ');

                            if ($query->num_rows)
                            {
                                $url .= '/' . $query->row['keyword'];
                            }
                        }

                        unset($data[$key]);
                    } else
                    {
                        $query = $this->db->query('SELECT * FROM ' . DB_PREFIX .
                            'url_alias WHERE `query` = '' . $this->db->escape($data['route']) . ');

                        if ($query->num_rows)
                        {
                            $url .= '/' . $query->row['keyword'];

                            unset($data[$key]);
                        }
                    }


                }
            }

            $link = str_replace('index.php?route=', '', $link);


            if ($url)
            {
                unset($data['route']);

                $query = '';

                if ($data)
                {
                    foreach ($data as $key => $value)
                    {
                        $query .= '&' . $key . '=' . $value;
                    }

                    if ($query)
                    {
                        $query = '?' . trim($query, '&');
                    }
                }

                return $url_data['scheme'] . '://' . $url_data['host'] . (isset($url_data['port']) ?
                    ':' . $url_data['port'] : '') . str_replace('/index.php', '', $url_data['path']) .
                    $url . $query;
            } else
            {
                return $link;
            }
        } else
        {
            return $link;
        }
    }
    
   //****
 
 }
создано: 2013-09-01
обновлено: 2021-03-13
137954



Рейтиг 5 of 10. count vote: 2
Вы довольны ?:
Поделиться:

Найди готовое или заработай

С нашими удобными сервисами без комиссии*

Как это работает? | Узнать цену?

Найти исполнителя
$0 / весь год.
  • У вас есть задание, но нет времени его делать
  • Вы хотите найти профессионала для выплнения задания
  • Возможно примерение функции гаранта на сделку
  • Приорететная поддержка
  • идеально подходит для студентов, у которых нет времени для решения заданий
Готовое решение
$0 / весь год.
  • Вы можите продать(исполнителем) или купить(заказчиком) готовое решение
  • Вам предоставят готовое решение
  • Будет предоставлено в минимальные сроки т.к. задание уже готовое
  • Вы получите базовую гарантию 8 дней
  • Вы можете заработать на материалах
  • подходит как для студентов так и для преподавателей
Я исполнитель
$0 / весь год.
  • Вы профессионал своего дела
  • У вас есть опыт и желание зарабатывать
  • Вы хотите помочь в решении задач или написании работ
  • Возможно примерение функции гаранта на сделку
  • подходит для опытных студентов так и для преподавателей



Комментарии

Timur
21-12-2019
Очень полезная информация
вася
22-05-2020
А по-русски ты уже разучился пояснять?
Админ
22-05-2020
на выходных постараюсь, как будет время расписать как для младенцев)
Guest
14-12-2020
НЕТ ЖИРНОГО

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

Выполнение скриптов на стороне сервера PHP (LAMP) NodeJS (Backend)

Термины: Выполнение скриптов на стороне сервера PHP (LAMP) NodeJS (Backend)