Php 结果页面未显示筛选的项目opencart

Php 结果页面未显示筛选的项目opencart,php,opencart,Php,Opencart,因此,我试图使用Opencart建立一个类似MVCL的站点,但是一旦我看到了我的筛选列表,我就选择了我想要检索的索引和结果,但结果只是显示了所有内容 它适用于其他类别,如按客户排序 我将解释我认为可能是问题的原因,而不是一大堆又一大堆的代码 在显示过滤列表之前,用户会在名为kit的索引中看到一组项目选项 然后循环此索引,用户选择他们选择的选项(例如,丰田将导致所有丰田品牌的汽车),但它会显示所有未应用过滤器的产品 型号: <?php class ModelCatalogKit extend

因此,我试图使用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;
        }
    }

}
?>
这个

if(!isset($this->data['kit'][$key])){
$this->data['categories'][$key]['kit']=$key;
}
没有用,因为
$this->data['categories'][$key]['kit']=$key始终被此文件覆盖

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

并且您的模型容易受到SQL注入的影响:

$query=$this->db->query(“SELECT*FROM”.db\u PREFIX.“product\u custom WHERE kit=”“$kit\u id.”);
应该转化为

$query=$this->db->query(“SELECT*FROM”.db\u PREFIX.“product\u custom WHERE kit='”(int)$kit\u id.“”;

$query=$this->db->query(“SELECT*FROM”.db\u PREFIX.“product\u custom WHERE kit=”””)“$this->db->escape($kit\u id)。””;

很难看出您想要做什么,但我猜您的MySQL中有一个名为product_custom的表,该表中有一列名为“kit”。。。然后您试图返回该表中所有具有“kit”值的行

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

目前它说:

    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)
            );
        }
    }
您可以将其更改为以下内容:

    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)
            );
        }
    }
至少这意味着只有在特定行具有“kit”值时,查询结果才会添加到数组中

正如我所说的,如果不充分了解您正在尝试做什么,不了解您的表格布局等,很难说

希望这有帮助

问候


杰里米,

好的,我终于明白了。似乎没有显示数据的原因是过滤器不工作。
为了改变这一点,我必须在product.php中创建一个新函数来过滤数据并显示产品。

谢谢你,到目前为止,我甚至没有意识到这个漏洞。我已经在原始代码中添加了一些内容。是否有任何原因让我获得正确的索引,但一旦我选择了它,查询结果将检索所有内容。在您选择selectbox中的具体工具包集后,发布负责加载结果的代码。。。您如何在模板中处理
$this->data['categories'][$key]['kit']
???