Opencart Seo Url Issue - PullRequest
       39

Opencart Seo Url Issue

0 голосов
/ 05 марта 2020

Я работаю над SEO URL открытой тележкой. Я использовал расширение (SEO Keyword Lite) для управления SEO URL opencart 2.3.0.2. Проблема в том, что когда я добавляю SEO URL для любого продукта или категории до 1 сегмента, т.е. http://baseurl/product-name, он работает нормально, но когда я добавляю SEO URL до 2 сегментов, т.е. http://baseurl/product/product-name он показывает ошибку, что «Запрошенная страница не может быть найдена!»

My Seo Url File:

class ControllerStartupSeoUrl extends Controller {
    public function index() {
        // Add rewrite to url class
        if ($this->config->get('config_seo_url')) {
            $this->url->addRewrite($this);
        }

        // Decode URL
        if (isset($this->request->get['_route_'])) {
            $parts = explode('/', $this->request->get['_route_']);

            // remove any empty arrays from trailing
            if (utf8_strlen(end($parts)) == 0) {
                array_pop($parts);
            }

            foreach ($parts as $part) {
                $query = $this->db->query("SELECT * FROM " . DB_PREFIX . "url_alias WHERE keyword = '" . $this->db->escape($part) . "'");

                if ($query->num_rows) {
                    $url = explode('=', $query->row['query']);

                    if ($url[0] == 'product_id') {
                        $this->request->get['product_id'] = $url[1];
                    }

                    if ($url[0] == 'category_id') {
                        if (!isset($this->request->get['path'])) {
                            $this->request->get['path'] = $url[1];
                        } else {
                            $this->request->get['path'] .= '_' . $url[1];
                        }
                    }

                    if ($url[0] == 'manufacturer_id') {
                        $this->request->get['manufacturer_id'] = $url[1];
                    }

                    if ($url[0] == 'information_id') {
                        $this->request->get['information_id'] = $url[1];
                    }

                    if ($query->row['query'] && $url[0] != 'information_id' && $url[0] != 'manufacturer_id' && $url[0] != 'category_id' && $url[0] != 'product_id') {
                        $this->request->get['route'] = $query->row['query'];
                    }
                } else {
                    $this->request->get['route'] = 'error/not_found';

                    break;
                }
            }

            if (!isset($this->request->get['route'])) {
                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';
                }
            }
        }
    }

    public function rewrite($link) {
        $url_info = parse_url(str_replace('&', '&', $link));

        $url = '';

        $data = array();

        parse_str($url_info['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 && $query->row['keyword']) {
                        $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 && $query->row['keyword']) {
                            $url .= '/' . $query->row['keyword'];
                        } else {
                            $url = '';

                            break;
                        }
                    }

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

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

            $query = '';

            if ($data) {
                foreach ($data as $key => $value) {
                    $query .= '&' . rawurlencode((string)$key) . '=' . rawurlencode((is_array($value) ? http_build_query($value) : (string)$value));
                }

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

            return $url_info['scheme'] . '://' . $url_info['host'] . (isset($url_info['port']) ? ':' . $url_info['port'] : '') . str_replace('/index.php', '', $url_info['path']) . $url . $query;
        } else {
            return $link;
        }
    }
}

Я пытался print_r () на каждом шагу и пробовал мои решения, но показывает тот же запрос не найден. Я понимаю, что URL-адрес seo работает соответствующим образом, но он не может найти ресурсы, связанные с URL-адресом, и показывает «запрос не найден». Я новичок в открытии корзины, буду признателен, если кто-нибудь проведет меня через это. Спасибо.

1 Ответ

0 голосов
/ 05 марта 2020

Я нашел ответ для настройки SEO URL, просто поместите строку кода в функцию перезаписи:

public function rewrite($link) {
        $url_info = parse_url(str_replace('&', '&', $link));

        $url = '';

        $data = array();

        parse_str($url_info['query'], $data);

            if ($data['route'] == 'common/home'){
                $url .= '/';
            }
            if ($data['route'] == 'information/contact'){
                $url .= '/contact';
            }
            if ($data['route'] == 'account/return/add'){
                $url .= '/returnadd';
            }
            if ($data['route'] == 'information/sitemap'){
                $url .= '/sitemap';
            }
            if ($data['route'] == 'product/manufacturer'){
                $url .= '/manufacturer';
            }
            if ($data['route'] == 'account/voucher'){
                $url .= '/voucher';
            }
            if ($data['route'] == 'affiliate/login'){
                $url .= '/affiliatelogin';
            }
            if ($data['route'] == 'product/special'){
                $url .= '/special';
            }
                    if ($data['route'] == 'product/product'){
                $url .= '/product';
            }

                        if ($data['route'] == 'product/category'){
                $url .= '/category';
            }
            if ($data['route'] == 'account/login'){
                $url .= '/login';
            }
            if ($data['route'] == 'checkout/cart'){
                $url .= '/cart';
            }

        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 && $query->row['keyword']) {
                        $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 && $query->row['keyword']) {
                            $url .= '/' . $query->row['keyword'];
                        } else {
                            $url = '';

                            break;
                        }
                    }

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

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

            $query = '';

            if ($data) {
                foreach ($data as $key => $value) {
                    $query .= '&' . rawurlencode((string)$key) . '=' . rawurlencode((is_array($value) ? http_build_query($value) : (string)$value));
                }

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

            return $url_info['scheme'] . '://' . $url_info['host'] . (isset($url_info['port']) ? ':' . $url_info['port'] : '') . str_replace('/index.php', '', $url_info['path']) . $url . $query;
        } else {
            return $link;
        }
    }

и самое важное упомяните эти ключевые слова в oc_url_alias как:

query= product/category   keyword=category

Я надеюсь, что это поможет многим людям, сталкивающимся с проблемой, касающейся seo url.

Спасибо.

...