//ecshop 2.7.2
// define是php里定义常量用的。第一个参数是常量名,第二个是常量的值。
// 它定义这个常量的作用是防止被引用文件的非法载入。
// 根据某人的说法, 挂个鸟牌。
define('IN_ECS', true);
//dirname(__FILE__) 取到的是当前文件的绝对路径
// 引入内核文件
require(dirname(__FILE__) . '/includes/init.php');
// DEBUG_MODE在init.php中定义了0,根据常量不可重复定义的原则,
估计下面的判断永远都将是真.即不需要更新缓存。
// $smarty->caching 为true时, 表示不强制更新缓存。
if ((DEBUG_MODE & 2) != 2)
{
$smarty->caching = true;
}
//strtolower大写转小写
$ua = strtolower($_SERVER['HTTP_USER_AGENT']);
$uachar =
"/(nokia|sony|ericsson|mot|samsung|sgh|lg|philips|panasonic|alcatel|lenovo|cldc|midp|mobile)/i";
if(($ua == '' || preg_match($uachar,
$ua))&&
!strpos(strtolower($_SERVER['REQUEST_URI']),'wap'))
{
$Loaction =
'mobile/';
if
(!empty($Loaction))
{
ecs_header("Location: $Loaction\n");
exit;
}
}
//-- Shopex系统地址转换
if (!empty($_GET['gOo']))
{
if
(!empty($_GET['gcat']))
{
$Loaction = 'category.php?id=' . $_GET['gcat'];
}
elseif
(!empty($_GET['acat']))
{
$Loaction = 'article_cat.php?id=' . $_GET['acat'];
}
elseif
(!empty($_GET['goodsid']))
{
$Loaction = 'goods.php?id=' . $_GET['goodsid'];
}
elseif
(!empty($_GET['articleid']))
{
$Loaction = 'article.php?id=' . $_GET['articleid'];
}
if
(!empty($Loaction))
{
ecs_header("Location: $Loaction\n");
exit;
}
}
//判断是否有ajax请求
$act = !empty($_GET['act']) ? $_GET['act'] : '';
if ($act == 'cat_rec')
{
$rec_array =
array(1 => 'best', 2 => 'new', 3
=> 'hot');
//假如有类型传过来就设置为数值类型,否则为1
$rec_type
= !empty($_REQUEST['rec_type']) ? intval($_REQUEST['rec_type']) :
'1';
$cat_id =
!empty($_REQUEST['cid']) ? intval($_REQUEST['cid']) : '0';
//json应用。
include_once('includes/cls_json.php');
$json = new
JSON;
$result = array('error'
=> 0, 'content' => '', 'type'
=> $rec_type, 'cat_id' =>
$cat_id);
//获得指定分类下所有底层分类的ID
$children
= get_children($cat_id);
$smarty->assign($rec_array[$rec_type] .
'_goods', get_category_recommend_goods($rec_array[$rec_type],
$children)); // 推荐商品
$smarty->assign('cat_rec_sign', 1);
$result['content'] =
$smarty->fetch('library/recommend_' .
$rec_array[$rec_type] . '.lbi');
die($json->encode($result));
}
//-- 判断是否存在缓存,如果存在则调用缓存,反之读取相应内容
// ecshop似乎没有用户选择模式功能吧, 以下加密串多少有点令人难理解.
$cache_id = sprintf('%X', crc32($_SESSION['user_rank'] . '-' .
$_CFG['lang']));
// $smarty->is_cached 方法有多低能就有多低能. 方法将返回false 或者
true.
if (!$smarty->is_cached('index.dwt',
$cache_id))
{ //设置默认的smarty变量数据.
assign_template();
//取得当前页信息.比如标题,链接等.
$position =
assign_ur_here();
//将它赋给smarty.
$smarty->assign('page_title', $position['title']); // 页面标题
$smarty->assign('ur_here', $position['ur_here']); // 当前位置
$smarty->assign('keywords', htmlspecialchars($_CFG['shop_keywords']));
$smarty->assign('description', htmlspecialchars($_CFG['shop_desc']));
$smarty->assign('flash_theme', $_CFG['flash_theme']); // Flash轮播图片模板
$smarty->assign('feed_url', ($_CFG['rewrite'] == 1) ? 'feed.xml' : 'feed.php'); // RSS URL
$smarty->assign('categories', get_categories_tree()); // 分类树
$smarty->assign('helps', get_shop_help()); // 网店帮助
$smarty->assign('top_goods', get_top10()); // 销售排行
$smarty->assign('best_goods', get_recommend_goods('best')); // 推荐商品
$smarty->assign('new_goods', get_recommend_goods('new')); // 最新商品
$smarty->assign('hot_goods', get_recommend_goods('hot')); // 热点文章
$smarty->assign('promotion_goods',
get_promote_goods()); // 特价商品
$smarty->assign('brand_list', get_brands());
$smarty->assign('promotion_info', get_promotion_info()); // 增加一个动态显示所有促销信息的标签栏
$smarty->assign('invoice_list', index_get_invoice_query()); // 发货查询
$smarty->assign('new_articles', index_get_new_articles()); //
最新文章
$smarty->assign('group_buy_goods',
index_get_group_buy()); // 团购商品
$smarty->assign('auction_list', index_get_auction()); // 拍卖活动
$smarty->assign('shop_notice', $_CFG['shop_notice']); // 商店公告
('index_ad', $_CFG['index_ad']);
if
($_CFG['index_ad'] == 'cus')
{
$sql = 'SELECT ad_type, content, url FROM ' .
$ecs->table("ad_custom") . ' WHERE ad_status =
1';
$ad = $db->getRow($sql, true);
$smarty->assign('ad', $ad);
}
$links =
index_get_links();
$smarty->assign('img_links', $links['img']);
$smarty->assign('txt_links', $links['txt']);
$smarty->assign('data_dir', DATA_DIR); // 数据目录
$cat_recommend_res = $db->getAll("SELECT c.cat_id,
c.cat_name, cr.recommend_type FROM " .
$ecs->table("cat_recommend") . " AS cr INNER JOIN "
. $ecs->table("category") . " AS c ON
cr.cat_id=c.cat_id");
if
(!empty($cat_recommend_res))
{
$cat_rec_array = array();
foreach($cat_recommend_res as $cat_recommend_data)
{
$cat_rec[$cat_recommend_data['recommend_type']][] = array('cat_id'
=> $cat_recommend_data['cat_id'], 'cat_name'
=> $cat_recommend_data['cat_name']);
}
$smarty->assign('cat_rec', $cat_rec);
}
assign_dynamic('index');
}
$smarty->display('index.dwt', $cache_id);
//-- PRIVATE FUNCTIONS
function index_get_invoice_query()
{
$sql =
'SELECT o.order_sn, o.invoice_no, s.shipping_code FROM ' .
$GLOBALS['ecs']->table('order_info') . ' AS o'
.
' LEFT JOIN ' . $GLOBALS['ecs']->table('shipping') .
' AS s ON s.shipping_id = o.shipping_id' .
" WHERE invoice_no > '' AND shipping_status = " .
SS_SHIPPED .
' ORDER BY shipping_time DESC LIMIT 10';
$all =
$GLOBALS['db']->getAll($sql);
foreach
($all AS $key => $row)
{
$plugin = ROOT_PATH . 'includes/modules/shipping/' .
$row['shipping_code'] . '.php';
if (file_exists($plugin))
{
include_once($plugin);
$shipping = new $row['shipping_code'];
$all[$key]['invoice_no'] =
$shipping->query((string)$row['invoice_no']);
}
}
clearstatcache();
return
$all;
}
function index_get_new_articles()
{
$sql =
'SELECT a.article_id, a.title, ac.cat_name, a.add_time, a.file_url,
a.open_type, ac.cat_id, ac.cat_name ' .
' FROM ' . $GLOBALS['ecs']->table('article') . ' AS
a, ' .
$GLOBALS['ecs']->table('article_cat') . ' AS ac'
.
' WHERE a.is_open = 1 AND a.cat_id = ac.cat_id AND ac.cat_type = 1'
.
' ORDER BY a.article_type DESC, a.add_time DESC LIMIT ' .
$GLOBALS['_CFG']['article_number'];
$res =
$GLOBALS['db']->getAll($sql);
$arr =
array();
foreach
($res AS $idx => $row)
{
$arr[$idx]['id'] = $row['article_id'];
$arr[$idx]['title'] = $row['title'];
$arr[$idx]['short_title'] =
$GLOBALS['_CFG']['article_title_length'] > 0 ?
sub_str($row['title'], $GLOBALS['_CFG']['article_title_length']) :
$row['title'];
$arr[$idx]['cat_name'] = $row['cat_name'];
$arr[$idx]['add_time'] = local_date($GLOBALS['_CFG']['date_format'],
$row['add_time']);
$arr[$idx]['url'] = $row['open_type'] != 1 ?
build_uri('article', array('aid' =>
$row['article_id']), $row['title']) : trim($row['file_url']);
$arr[$idx]['cat_url'] = build_uri('article_cat', array('acid' =>
$row['cat_id']), $row['cat_name']);
}
return
$arr;
}
function index_get_group_buy()
{
$time =
gmtime();
$limit =
get_library_number('group_buy', 'index');
$group_buy_list = array();
if ($limit
> 0)
{
$sql = 'SELECT gb.act_id AS group_buy_id, gb.goods_id, gb.ext_info,
gb.goods_name, g.goods_thumb, g.goods_img ' .
'FROM ' . $GLOBALS['ecs']->table('goods_activity') .
' AS gb, ' .
$GLOBALS['ecs']->table('goods') . ' AS g ' .
"WHERE gb.act_type = '" . GAT_GROUP_BUY . "' " .
"AND g.goods_id = gb.goods_id " .
"AND gb.start_time <= '" . $time . "' " .
"AND gb.end_time >= '" . $time . "' " .
"AND g.is_delete = 0 " .
"ORDER BY gb.act_id DESC " .
"LIMIT $limit" ;
$res = $GLOBALS['db']->query($sql);
while ($row = $GLOBALS['db']->fetchRow($res))
{
$row['goods_img'] = get_image_path($row['goods_id'],
$row['goods_img']);
$row['thumb'] = get_image_path($row['goods_id'],
$row['goods_thumb'], true);
$ext_info = unserialize($row['ext_info']);
$price_ladder = $ext_info['price_ladder'];
if (!is_array($price_ladder) || empty($price_ladder))
{
$row['last_price'] = price_format(0);
}
else
{
foreach ($price_ladder AS $amount_price)
{
$price_ladder[$amount_price['amount']] =
$amount_price['price'];
}
}
ksort($price_ladder);
$row['last_price'] = price_format(end($price_ladder));
$row['url'] = build_uri('group_buy', array('gbid' =>
$row['group_buy_id']));
$row['short_name'] =
$GLOBALS['_CFG']['goods_name_length'] > 0 ?