所以我正在尝试使用 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);
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_id=' . $key)
);
$this->data['kit'][$key]
设置在哪里?
并且您的模型容易受到SQL注入的影响:
$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 . "'");
或
$query = $this->db->query("SELECT * FROM " . DB_PREFIX . "product_custom WHERE kit='" . $this->db->escape($kit_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)
);
}
}
至少这意味着只有当该特定行具有"kit"的值时,查询结果才会添加到数组中
正如我所说,如果不完全看到您要做什么并了解您的表格布局等,很难说
希望这有帮助,
问候
杰里米
好吧,
我最后想通了。似乎没有显示数据的原因是过滤器不起作用。为了改变这一点,我必须在产品中创建一个新功能.php它将过滤数据并显示产品。