结果页面未显示已过滤的项目opencart

时间:2013-10-21 09:11:06

标签: php opencart

所以我试图使用Opencart建立一个类似MVCL的网站,但是一旦我看到我的过滤列表,我选择索引和我希望检索的结果,但它只是导致显示一切。

适用于其他类别,例如按客户排序。

我会解释我认为可能导致问题的原因,而不是显示大量的代码。

在显示已过滤的列表之前,用户会在名为kit的索引中显示该项目的一组选项。

然后循环该索引并且用户将选择他们选择的选项(例如丰田将导致制造丰田的所有汽车)但是它显示所有没有应用过滤器的产品。

型号:

<?php
class ModelCatalogKit extends Model {
    public function getKit($kit_id) {
        $query = $this->db->query("SELECT * FROM " . DB_PREFIX . "product_custom WHERE kit='" . $kit_id . "'");

        return $query->row;
    }

    public function getKits($data = array()) {

        if ($data) {
            $sql = "SELECT * FROM " . DB_PREFIX . "product_custom group by kit ";

            $sort_data = array(
                'name',
                'sort_order'
            );
            if (isset($data['sort']) && in_array($data['sort'], $sort_data)) {
                $sql .= " ORDER BY " . $data['sort'];
            } else {
                $sql .= " ORDER BY name";
            }

            if (isset($data['order']) && ($data['order'] == 'DESC')) {
                $sql .= " DESC";
            } else {
                $sql .= " ASC";
            }

            if (isset($data['start']) || isset($data['limit'])) {
                if ($data['start'] < 0) {
                    $data['start'] = 0;
                }

                if ($data['limit'] < 1) {
                    $data['limit'] = 20;
                }

                $sql .= " LIMIT " . (int)$data['start'] . "," . (int)$data['limit'];
            }

            $query = $this->db->query($sql);

            return $query->rows;
        } else {
            $kit_data = $this->cache->get('kit.' . (int)$this->config->get('config_store_id'));

            if (!$kit_data) {
                $query = $this->db->query("SELECT distinct kit FROM " . DB_PREFIX . "product_custom ORDER BY kit");

                $kit_data = $query->rows;

                $this->cache->set('kit.' . (int)$this->config->get('config_store_id'), $kit_data);
            }

            return $kit_data;
        }
    }

}
?>

控制器:

$this->data['categories'] = array();

        $results = $this->model_catalog_kit->getKits();

        foreach ($results as $result) {

            $key = $result['kit'];

            $this->data['categories'][$key]['kit']= array(
                'name' => $result['kit'],
                'href' => $this->url->link('product/kit/info', 'kit_id=' . $key)
            );
        }

$kit_info = $this->model_catalog_kit->getKit($kit_id);
var_dump($kit_info);

3 个答案:

答案 0 :(得分:1)

if (!isset($this->data['kit'][$key])) {
    $this->data['categories'][$key]['kit'] = $key;
}

没用,因为{<1}}总是被

覆盖
$this->data['categories'][$key]['kit'] = $key;

$this->data['categories'][$key]['kit'] = array( 'name' => $result['kit'], 'href' => $this->url->link('product/kit/info', 'kit_id=' . $key) ); 设置在哪里?

您的模型容易受到 SQL注入

的攻击
$this->data['kit'][$key]

应该转化为

$query = $this->db->query("SELECT * FROM " . DB_PREFIX . "product_custom WHERE kit='" . $kit_id . "'");

$query = $this->db->query("SELECT * FROM " . DB_PREFIX . "product_custom WHERE kit='" . (int)$kit_id . "'");

答案 1 :(得分:0)

很难看到你想要做什么,但我想你的MySQL中有一个名为product_custom的表,你在该表中有一个名为&#34; kit&#34; ...然后你是尝试返回该表中具有&#34; kit&#34;?

值的所有行

如果是这样,我会尝试以下

目前它说的如下:

    foreach ($results as $result) {

        $key = $result['kit'];

        $this->data['categories'][$key]['kit']= array(
            'name' => $result['kit'],
            'href' => $this->url->link('product/kit/info', 'kit_id=' . $key)
        );
    }

您可以将其更改为以下内容:

    foreach ($results as $result) {

        if (isset($result['kit'])) {
            $key = $result['kit'];

            $this->data['categories'][$key]['kit']= array(
                'name' => $result['kit'],
                'href' => $this->url->link('product/kit/info', 'kit_id=' . $key)
            );
        }
    }

至少这意味着只有当该特定行具有&#34; kit&#34;

的值时,才会将查询结果添加到数组中

正如我所说,如果没有完全看到你想要做的事情并且知道你的桌子布局等,很难说

希望这有帮助,

此致

杰里米,

答案 2 :(得分:0)

好的,我最终弄明白了。似乎没有数据显示的原因是因为过滤器不起作用。 为了改变这种情况,我必须在product.php中创建一个新功能,用于过滤数据并显示产品。

相关问题