pick out.php,pick_out.php
/**
* 选购中心
* ============================================================================
* * 版权所有 badboy Taolee
* ============================================================================
* $Author: Taolee 1434926265@qq.com
* $Id: pick_out.php
*/
define('IN_ECS', true);
require(dirname(__FILE__) . '/includes/init.php');
$condition = array();
$picks = array();
$cat_id = !empty($_GET['cat_id']) ? intval($_GET['cat_id']) : 0;
if (!empty($_GET['attr']))
{
foreach($_GET['attr'] as $key => $value)
{
if (!is_numeric($key))
{
unset($_GET['attr'][$key]);
continue;
}
$key = intval($key);
$_GET['attr'][$key] = htmlspecialchars($value);
}
}
if (empty($cat_id))
{
/* 获取所有符合条件的商品类型 */
$sql = "SELECT DISTINCT t.cat_id, t.cat_name " .
"FROM " . $ecs->table('goods_type') . " AS t, " . $ecs->table('attribute') . " AS a, " . $ecs->table('goods_attr') . " AS g " .
"WHERE t.cat_id = a.cat_id AND a.attr_id = g.attr_id AND t.enabled = 1";
$rs = $db->query($sql);
$in_cat = array();
$cat_name = array();
$in_goods = '';
while ($row = $db->fetchRow($rs))
{
$condition[$row['cat_id']]['name'] = $row['cat_name'];
$in_cat[] = $row['cat_id'];
}
$in_cat = "AND a.cat_id ".db_create_in($in_cat);
/* 获取符合条件的属性 */
$sql = "SELECT DISTINCT a.attr_id ".
"FROM ".$ecs->table('goods_attr')." AS g, ".$ecs->table('attribute') ." AS a ".
"WHERE a.attr_id = g.attr_id " . $in_cat;
$in_attr = $db->getCol($sql); //符合条件attr_id;
$in_attr = 'AND g.attr_id '.db_create_in($in_attr);
/* 获取所有属性值 */
$sql = "SELECT DISTINCT g.attr_id, a.attr_name, a.cat_id, g.attr_value".
" FROM ".$ecs->table('goods_attr')." AS g, ".
$ecs->table('attribute') ." AS a".
" WHERE a.attr_id = g.attr_id ".$in_attr." ORDER BY cat_id";
$rs = $db->query($sql);
while ($row = $db->fetchRow($rs))
{
if (empty($condition[$row['cat_id']]['cat'][$row['attr_id']]['cat_name']))
{
$condition[$row['cat_id']]['cat'][$row['attr_id']]['cat_name'] = $row['attr_name'];
}
$condition[$row['cat_id']]['cat'][$row['attr_id']]['list'][] = array('name'=>$row['attr_value'], 'url'=>'pick_out.php?cat_id='.$row['cat_id'].'&attr['.$row['attr_id'].']='.urlencode($row['attr_value']));
}
/* 获取商品总数 */
$goods_count = $db->GetOne("SELECT COUNT(DISTINCT(goods_id)) FROM " . $ecs->table('goods_attr'));
/* 获取符合条件的商品id */
//$sql = "SELECT DISTINCT goods_id FROM " .$ecs->table('goods_attr'). " LIMIT 100";
$sql = "SELECT DISTINCT goods_id FROM " .$ecs->table('goods_attr');
$in_goods = $db->GetCol($sql);
$in_goods = 'AND g.goods_id ' . db_create_in(implode(',', $in_goods));
$url = "search.php?pickout=1";
}
else
{
/* 取得商品类型名称 */
$sql = "SELECT cat_name FROM ".$ecs->table('goods_type')." WHERE cat_id = '$cat_id'";
$cat_name = $db->GetOne($sql);
$condition[0]['name'] = $cat_name;
$picks[] = array('name'=>''.$_LANG['goods_type'].':
'.$cat_name, 'url'=>'pick_out.php');
$attr_picks = array(); //选择过的attr_id
/* 处理属性,获取满足属性的goods_id */
if (!empty($_GET['attr']))
{
$attr_table = '';
$attr_where = '';
$attr_url = '';
$i = 0;
$goods_result = '';
foreach ($_GET['attr'] AS $key => $value)
{
$attr_url .= '&attr[' . $key . ']=' . $value;
$attr_picks[] = $key;
if ($i > 0)
{
if (empty($goods_result))
{
break;
}
$goods_result = $db->getCol("SELECT goods_id FROM " . $ecs->table("goods_attr") . " WHERE goods_id IN (" . implode(',' , $goods_result) . ") AND attr_id='$key' AND attr_value='$value'");
}
else
{
$goods_result = $db->getCol("SELECT goods_id FROM " . $ecs->table("goods_attr") . " WHERE attr_id='$key' AND attr_value='$value'");
}
$i++;
}
/* 获取指定attr_id的名字 */
$sql = "SELECT attr_id, attr_name FROM ".$ecs->table('attribute')." WHERE attr_id ".db_create_in(implode(',',$attr_picks));
$rs = $db->query($sql);
while ($row = $db->fetchRow($rs))
{
$picks[] = array('name'=>''.$row['attr_name'].':
'.htmlspecialchars(urldecode($_GET['attr'][$row['attr_id']])), 'url'=>'pick_out.php?cat_id='.$cat_id.search_url($attr_picks, $row['attr_id']));
}
/* 查出数量 */
$goods_count = count($goods_result);
/* 获取符合条件的goods_id */
$in_goods = 'AND g.goods_id '.db_create_in(implode(',', $goods_result));
}
else
{
/* 仅选择了商品类型的情况 */
/* 查出数量 */
$goods_count = $db->GetOne("SELECT COUNT(distinct(g.goods_id)) FROM ".$ecs->table('goods_attr')." AS g, ".$ecs->table('attribute')." AS a WHERE g.attr_id = a.attr_id AND a.cat_id = '$cat_id' ");
/* 防止结果过大,最多只查出前100个goods_id */
$sql = "SELECT DISTINCT g.goods_id FROM ".$ecs->table('goods_attr')." AS g, ".$ecs->table('attribute')." AS a WHERE g.attr_id = a.attr_id AND a.cat_id = '$cat_id' LIMIT 100";
$in_goods = $db->GetCol($sql);
$in_goods = 'AND g.goods_id '.db_create_in(implode(',', $in_goods));
}
/* 获取符合条件的属性 */
$sql = "SELECT DISTINCT a.attr_id FROM ".$ecs->table('goods_attr')." AS g, ".$ecs->table('attribute') ." AS a ".
"WHERE a.attr_id = g.attr_id " . $in_goods;
$in_attr = $db->GetCol($sql); // 符合条件attr_id;
$in_attr = array_diff($in_attr, $attr_picks); // 除去已经选择过的attr_id
$in_attr = 'AND g.attr_id '.db_create_in(implode(',', $in_attr));
/* 获取所有属性值 */
$sql = "SELECT DISTINCT g.attr_id, a.attr_name, g.attr_value FROM ".$ecs->table('goods_attr')." AS g, ".$ecs->table('attribute') ." AS a WHERE a.attr_id = g.attr_id ".$in_attr.$in_goods;
$rs = $db->query($sql);
while ($row = $db->fetchRow($rs))
{
if (empty($condition[0]['cat'][$row['attr_id']]['cat_name']))
{
$condition[0]['cat'][$row['attr_id']]['cat_name'] = $row['attr_name'];
}
$condition[0]['cat'][$row['attr_id']]['list'][] = array('name'=>$row['attr_value'], 'url'=>'pick_out.php?cat_id='.$cat_id.search_url($attr_picks).'&attr['.$row['attr_id'].']='.urlencode($row['attr_value']));
}
/* 生成更多商品的url */
$url = "search.php?pickout=1&cat_id=".$cat_id.search_url($attr_picks);
}
/* 显示商品 */
$goods = array();
$sql = "SELECT g.goods_id, g.goods_name, g.market_price, g.shop_price AS org_price, ".
"IFNULL(mp.user_price, g.shop_price * '$_SESSION[discount]') AS shop_price, ".
"g.promote_price, promote_start_date, promote_end_date, g.goods_brief, g.goods_thumb ".
"FROM " .$ecs->table('goods'). " AS g ".
"LEFT JOIN " . $GLOBALS['ecs']->table('member_price') . " AS mp ".
"ON mp.goods_id = g.goods_id AND mp.user_rank = '$_SESSION[user_rank]' ".
"WHERE g.is_on_sale = 1 AND g.is_alone_sale = 1 AND g.is_delete = 0 ".$in_goods.
"ORDER BY g.sort_order, g.last_update DESC";
$res = $db->SelectLimit($sql, 4);
/* 获取品牌 */
$sql = "SELECT b.brand_id, b.brand_name, b.brand_logo, COUNT(g.goods_id) AS goods_num ".
" FROM " . $ecs->table('goods') . " AS g ".
" LEFT JOIN " . $ecs->table('brand') . " AS b ON g.brand_id=b.brand_id ".
" WHERE g.is_on_sale = 1 AND g.is_alone_sale = 1 AND g.is_delete = 0 AND b.brand_id > 0 " . $in_goods .
" GROUP BY g.brand_id ";
$brand_list = $db->getAll($sql);
foreach ($brand_list as $key=>$val)
{
$brand_list[$key]['url'] = $url . '&brand=' . $val['brand_id'];
}
/* 获取分类 */
$sql = "SELECT c.cat_id, c.cat_name, COUNT(g.goods_id) AS goods_num ".
" FROM " . $ecs->table('goods') . " AS g ".
" LEFT JOIN " . $ecs->table('category') . " AS c ON c.cat_id = g.cat_id ".
" WHERE g.is_on_sale = 1 AND g.is_alone_sale = 1 AND g.is_delete = 0 " . $in_goods .
" GROUP BY g.cat_id ";
$cat_list = $db->getAll($sql);
foreach ($cat_list as $key=>$val)
{
$cat_list[$key]['url'] = $url . '&category=' . $val['cat_id'];
}
$idx = 0;
while ($row = $db->fetchRow($res))
{
if ($row['promote_price'] > 0)
{
$promote_price = bargain_price($row['promote_price'], $row['promote_start_date'], $row['promote_end_date']);
}
else
{
$promote_price = 0;
}
$goods[$idx]['id'] = $row['goods_id'];
$goods[$idx]['name'] = $row['goods_name'];
$goods[$idx]['short_name'] = $_CFG['goods_name_length'] > 0 ? sub_str($row['goods_name'], $_CFG['goods_name_length']) : $row['goods_name'];
$goods[$idx]['market_price'] = $row['market_price'];
$goods[$idx]['shop_price'] = price_format($row['shop_price']);
$goods[$idx]['promote_price'] = $promote_price > 0 ? price_format($promote_price) : '';
$goods[$idx]['brief'] = $row['goods_brief'];
$goods[$idx]['thumb'] = get_image_path($row['goods_id'], $row['goods_thumb'], true);
$goods[$idx]['url'] = build_uri('goods', array('gid'=>$row['goods_id']), $row['goods_name']);
$idx++;
}
$picks[] = array('name'=>$_LANG['remove_all'], 'url'=>'pick_out.php');
assign_template();
$position = assign_ur_here(0, $_LANG['pick_out']);
$smarty->assign('page_title', $position['title']); // 页面标题
$smarty->assign('ur_here', $position['ur_here']); // 当前位置
$smarty->assign('brand_list', $brand_list); //品牌
$smarty->assign('cat_list', $cat_list); //分类列表
$smarty->assign('categories', get_categories_tree()); // 分类树
$smarty->assign('helps', get_shop_help()); // 网店帮助
$smarty->assign('top_goods', get_top10()); // 销售排行
$smarty->assign('data_dir', DATA_DIR); // 数据目录
/* 调查 */
$vote = get_vote();
if (!empty($vote))
{
$smarty->assign('vote_id', $vote['id']);
$smarty->assign('vote', $vote['content']);
}
assign_dynamic('pick_out');
$smarty->assign('url', $url);
$smarty->assign('pickout_goods', $goods);
$smarty->assign('count', $goods_count);
$smarty->assign('picks', $picks);
$smarty->assign('condition', $condition);
$smarty->display('pick_out.dwt');
/**
* 生成搜索的链接地址
*
* @access public
* @param int attr_id 要排除的attr_id
*
* @return string
*/
function search_url(&$attr_picks, $attr_id = 0)
{
$str = '';
foreach ($attr_picks AS $pick_id)
{
if ($pick_id != $attr_id)
{
$str .= '&attr['.$pick_id.']='.urlencode($_GET['attr'][$pick_id]);
}
}
return $str;
}
?>
一键复制
编辑
Web IDE
原始数据
按行查看
历史
pick out.php,pick_out.php相关推荐
- echarts的词云图表类型有哪些_词云图的几种制作方法评测,你pick哪款
前言 大家好,不知道大家会在什么场合使用词云图,对我来说词云图的优点除了它可以展示大量文本数据.从而让读者快速抓住重点,更重要的是词云图好看啊所以今天给大家分享几种词云图的制作方法.首先我们来思考一下 ...
- 华为 | 人生苦短,码短情长,有场大Party等你来Pick!
上学时,书上说C语言是上帝的语言. 我同屋的兄弟不服,他说PHP才是最好的语言. 毕业之后,我们Team的老大却坚信:Life is short,只用Python-- 现在,作为一个真正的开发者,我发 ...
- ecshop /pick_out.php SQL Injection Vul By Local Variable Overriding
catalog 1. 漏洞描述 2. 漏洞触发条件 3. 漏洞影响范围 4. 漏洞代码分析 5. 防御方法 6. 攻防思考 1. 漏洞描述 在进行输入变量本地模拟注册的时候,没有进行有效的GPC模拟过 ...
- 好书征集第2弹 | 你pick哪本人工智能好书
上次的好书推荐栏目,我们征集到了很多大家喜欢的 Python 书 这次想让大家聊一聊喜欢的人工智能好书 我将选出优秀留言,把你的推荐撒向广大书友们! 让大家享受知识和智慧的洗涤,是不是一件很有意义的事 ...
- poj 1265 Area(pick 定理)
链接:poj 1265 题意:从原点出发.给出一些dx,dy移动增量,终于形成一个多边形, 求多边形内部的格点数目,边上的格点数目 .以及面积. 补充知识: 1.以格子点为顶点的线段.覆盖的点的个数为 ...
- 398. Random Pick Index - LeetCode
为什么80%的码农都做不了架构师?>>> Question 398. Random Pick Index Solution 思路:重点是如果数据中有多个数target相等,要从 ...
- pku 2954 Triangle pku 1265 Area Pick定理的应用 + 叉积求多边形面积
Pick定理证明:http://translate.google.com/translate?u=http://episte.math.ntu.edu.tw/articles/sm/sm_25_10_ ...
- mxnet pick挑选
mx.symbol.slice_axis可以直接在某一维上切割,选择整行或整列. pick 是精准挑选指定位置的值, 精准筛选指定位置的值. 代码格式,x,y都需要转成mxnet nd.array形式 ...
- 398. Random Pick Index
随机返还target值的坐标(如果存在多个target). 不太明白为什么这个题是M难度的. 无非是要么弄TABLE之类的,开始麻烦点,但是pick的时候直接PICK出来就行了. 要么开始简单点,都存 ...
- 【AI基础】OpenCV,PIL,Skimage你pick谁
文章首发于微信公众号<与有三学AI> [AI基础]OpenCV,PIL,Skimage你pick谁 如何对图像进行处理是深度学习图像处理的基础,我们常常需要对图像进行读取.保存.缩放.裁剪 ...
最新文章
- 解决“SSL handshake failed“问题
- python不想学了-十分钟也学不会python?就不要学python了
- spring学习之@ModelAttribute运用详解
- P5662-纪念品【dp】
- Java反射(Reflection)
- python父亲节祝福_父亲节祝福语精选简短 父亲节祝福语简短独特
- 服务器系统上1068错误,错误1068,详细教您启动网络服务错误1068怎么解决
- 【MyBatis框架】Mybatis开发dao方法第二部分
- 《万物互联》——2.3 理解智能设备
- python多线程队列两组数据_python 多线程2-队列同步
- object C—类中函数的调用
- PMP-132种工具技术合集-(第6版)
- 视频教程 | 3D 跑酷小游戏实战开发(上)
- android 增加定时开关机
- 云计算的运营方式有哪些?
- 【推荐软件】艾奇卡拉OK歌词字幕制作软件
- 浅析API网关——Ocelot[网关]+Consul[服务发现负载均衡]+Polly[服务熔断]+Ids4[服务认证]
- [二进制学习笔记]LibcSearcher报错no matched libc
- html盒模型中border的写法,CSS盒模型--边框设置:border: 1px solid red(像素 样式 颜色 ),border-bottom:1px dotted #ccc...
- 上海电信账单余额查询接口