VipcardController.class.php 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576
  1. <?php
  2. /**
  3. * lionfish 商城系统
  4. *
  5. * ==========================================================================
  6. * @link http://www.liofis.com/
  7. * @copyright Copyright (c) 2015 liofis.com.
  8. * @license http://www.liofis.com/license.html License
  9. * ==========================================================================
  10. * 拼团模块
  11. * @author fish
  12. *
  13. */
  14. namespace Home\Controller;
  15. class VipcardController extends CommonController {
  16. protected function _initialize()
  17. {
  18. parent::_initialize();
  19. }
  20. public function get_vipcard_baseinfo()
  21. {
  22. $_GPC = I('request.');
  23. $token = $_GPC['token'];
  24. $weprogram_token = M('lionfish_comshop_weprogram_token')->field('member_id')->where( array('token' => $token) )->find();
  25. $member_id = $weprogram_token['member_id'];
  26. if( empty($member_id) )
  27. {
  28. echo json_encode( array('code' =>1,'msg' =>'未登录') );
  29. die();
  30. }
  31. $member_id = $weprogram_token['member_id'];
  32. $member_info = M('lionfish_comshop_member')->where( array('member_id' => $member_id ) )->find();
  33. $vipcard_unopen_headbg = D('Home/Front')->get_config_by_name('vipcard_unopen_headbg');
  34. $vipcard_effect_headbg = D('Home/Front')->get_config_by_name('vipcard_effect_headbg');
  35. $vipcard_afterefect_headbg = D('Home/Front')->get_config_by_name('vipcard_afterefect_headbg');
  36. if(!empty($vipcard_unopen_headbg)) $vipcard_unopen_headbg = tomedia($vipcard_unopen_headbg);
  37. if(!empty($vipcard_effect_headbg)) $vipcard_effect_headbg = tomedia($vipcard_effect_headbg);
  38. if(!empty($vipcard_afterefect_headbg)) $vipcard_afterefect_headbg = tomedia($vipcard_afterefect_headbg);
  39. $vipcard_buy_pagenotice = D('Home/Front')->get_config_by_name('vipcard_buy_pagenotice');
  40. $vipcard_equity_notice = D('Home/Front')->get_config_by_name('vipcard_equity_notice');
  41. $vipcard_buy_pagenotice = htmlspecialchars_decode($vipcard_buy_pagenotice);
  42. $vipcard_equity_notice = htmlspecialchars_decode($vipcard_equity_notice);
  43. $card_list = M('lionfish_comshop_member_card')->select();
  44. $card_equity_list = M('lionfish_comshop_member_card_equity')->select();
  45. $result = array();
  46. //判断是否开启了 会员卡 is_open_vipcard_buy
  47. $is_open_vipcard_buy = D('Home/Front')->get_config_by_name('is_open_vipcard_buy');
  48. $modify_vipcard_name = D('Home/Front')->get_config_by_name('modify_vipcard_name');
  49. $is_hide_vipcard_vipgoods = D('Home/Front')->get_config_by_name('is_hide_vipcard_vipgoods');
  50. $is_show_vipgoods = empty($is_hide_vipcard_vipgoods) || $is_hide_vipcard_vipgoods == 0 ? 1 : 0;
  51. $modify_vipcard_name = empty($modify_vipcard_name) ? '天机会员': $modify_vipcard_name;
  52. $result['is_open_vipcard_buy'] = $is_open_vipcard_buy;
  53. $result['modify_vipcard_name'] = $modify_vipcard_name;
  54. $result['is_vip_card_member'] = 0;
  55. if( !empty($is_open_vipcard_buy) && $is_open_vipcard_buy == 1 )
  56. {
  57. $now_time = time();
  58. if( $member_info['card_id'] >0 && $member_info['card_end_time'] > $now_time )
  59. {
  60. $result['is_vip_card_member'] = 1;//还有会员
  61. $del_day = ceil( ($member_info['card_end_time'] - $now_time) / 86400 ) ;
  62. $result['del_vip_day'] = $del_day;
  63. }else if( $member_info['card_id'] >0 && $member_info['card_end_time'] < $now_time ){
  64. $result['is_vip_card_member'] = 2;//已过期
  65. }
  66. }
  67. if( !empty($card_equity_list) )
  68. {
  69. foreach($card_equity_list as $key => $val)
  70. {
  71. $val['image'] = tomedia($val['image'] );
  72. $card_equity_list[$key] = $val;
  73. }
  74. }
  75. $member_info['card_end_time'] = date('Y-m-d', $member_info['card_end_time']);
  76. $result['vipcard_unopen_headbg'] = $vipcard_unopen_headbg;
  77. $result['vipcard_effect_headbg'] = $vipcard_effect_headbg;
  78. $result['vipcard_afterefect_headbg'] = $vipcard_afterefect_headbg;
  79. $result['vipcard_buy_pagenotice'] = $vipcard_buy_pagenotice;
  80. $result['vipcard_equity_notice'] = $vipcard_equity_notice;
  81. $result['card_list'] = $card_list;
  82. $result['card_equity_list'] = $card_equity_list;
  83. $result['member_info'] = $member_info;
  84. $result['is_show_vipgoods'] = $is_show_vipgoods;//是否显示会员卡商品
  85. $category_list = M('lionfish_comshop_goods_category')->where( "cate_type='normal' and is_show=1 and pid=0" )->order('sort_order desc,id asc')->select();
  86. foreach( $category_list as &$val )
  87. {
  88. unset($val['uniacid']);
  89. unset($val['pid']);
  90. unset($val['is_hot']);
  91. unset($val['logo']);
  92. unset($val['banner']);
  93. unset($val['cate_type']);
  94. unset($val['sort_order']);
  95. unset($val['is_show_topic']);
  96. }
  97. $result['category_list'] = $category_list;
  98. echo json_encode( array('code' => 0, 'data' => $result) );
  99. die();
  100. }
  101. public function get_vipgoods_list()
  102. {
  103. $_GPC = I('request.');
  104. $head_id = $_GPC['head_id'];
  105. if($head_id == 'undefined') $head_id = '';
  106. $pageNum = isset($_GPC['pageNum']) && $_GPC['pageNum'] > 0 ? $_GPC['pageNum'] : 1 ;
  107. $gid = $_GPC['gid'];
  108. $keyword = '';
  109. $is_random = 0;
  110. $per_page = isset($_GPC['per_page']) ? $_GPC['per_page'] : 10;
  111. $cate_info = '';
  112. if($gid > 0){
  113. $sub_cate_list = M('lionfish_comshop_goods_category')->where( "is_show=1 and cate_type='normal' and pid = {$gid}" )->order('sort_order desc, id desc')->select();
  114. $gidArr = array();
  115. $gidArr[] = $gid;
  116. foreach ($sub_cate_list as $key => $val) {
  117. $gidArr[] = $val['id'];
  118. }
  119. $gid = implode(',', $gidArr);
  120. }
  121. $offset = ($pageNum - 1) * $per_page;
  122. $limit = "{$offset},{$per_page}";
  123. $token = $_GPC['token'];
  124. $weprogram_token = M('lionfish_comshop_weprogram_token')->field('member_id')->where( array('token' => $token) )->find();
  125. $is_vip_card_member = 0;
  126. $is_open_vipcard_buy = D('Home/Front')->get_config_by_name('is_open_vipcard_buy');
  127. $is_open_vipcard_buy = !empty($is_open_vipcard_buy) && $is_open_vipcard_buy ==1 ? 1:0;
  128. if( empty($weprogram_token) || empty($weprogram_token['member_id']) )
  129. {
  130. }else{
  131. $member_id = $weprogram_token['member_id'];
  132. $is_vip_card_member = 0;
  133. //member_id
  134. if( $member_id > 0 )
  135. {
  136. $member_info = M('lionfish_comshop_member')->where( array('member_id' => $member_id ) )->find();
  137. if( !empty($is_open_vipcard_buy) && $is_open_vipcard_buy == 1 )
  138. {
  139. $now_time = time();
  140. if( $member_info['card_id'] >0 && $member_info['card_end_time'] > $now_time )
  141. {
  142. $is_vip_card_member = 1;//还是会员
  143. }else if( $member_info['card_id'] >0 && $member_info['card_end_time'] < $now_time ){
  144. $is_vip_card_member = 2;//已过期
  145. }
  146. }
  147. }
  148. }
  149. $now_time = time();
  150. $where = " g.is_take_vipcard =1 and g.grounding =1 and g.type ='normal' ";
  151. //head_id
  152. if( !empty($head_id) && $head_id >0 )
  153. {
  154. if($gid == 0){
  155. $goods_ids_arr = M('lionfish_community_head_goods')->field('goods_id')->where( array('head_id' => $head_id ) )->select();
  156. } else {
  157. $sql_goods_ids = "select pg.goods_id from ".C('DB_PREFIX')."lionfish_community_head_goods as pg,"
  158. .C('DB_PREFIX')."lionfish_comshop_goods_to_category as g
  159. where pg.goods_id = g.goods_id and g.cate_id in ({$gid}) and pg.head_id = {$head_id} order by pg.id desc ";
  160. $goods_ids_arr = M()->query($sql_goods_ids);
  161. }
  162. $ids_arr = array();
  163. foreach($goods_ids_arr as $val){
  164. $ids_arr[] = $val['goods_id'];
  165. }
  166. if($gid == 0){
  167. $goods_ids_nolimit_arr = M('lionfish_comshop_goods')->field('id')->where( array('is_all_sale' => 1) )->select();
  168. } else {
  169. $goods_ids_nolimit_sql = "select pg.id from ".C('DB_PREFIX')."lionfish_comshop_goods as pg,"
  170. .C('DB_PREFIX')."lionfish_comshop_goods_to_category as g
  171. where pg.id = g.goods_id and g.cate_id in ({$gid}) and pg.is_all_sale=1 ";
  172. $goods_ids_nolimit_arr = M()->query($goods_ids_nolimit_sql);
  173. }
  174. if( !empty($goods_ids_nolimit_arr) )
  175. {
  176. foreach($goods_ids_nolimit_arr as $val){
  177. $ids_arr[] = $val['id'];
  178. }
  179. }
  180. $ids_str = implode(',',$ids_arr);
  181. if( !empty($ids_str) )
  182. {
  183. $where .= " and g.id in ({$ids_str})";
  184. } else{
  185. $where .= " and 0 ";
  186. }
  187. }else{
  188. //echo json_encode( array('code' => 1) );
  189. // die();
  190. if($gid == 0){
  191. $goods_ids_nohead_arr = M('lionfish_comshop_goods')->field('id')->where( array('type' => 'normal' ) )->select();
  192. } else {
  193. $goods_ids_nohead_sql = "select pg.id from ".C('DB_PREFIX')."lionfish_comshop_goods as pg,"
  194. .C('DB_PREFIX')."lionfish_comshop_goods_to_category as g where pg.id = g.goods_id and g.cate_id in ({$gid}) and type='normal' ";
  195. $goods_ids_nohead_arr = M()->query($goods_ids_nohead_sql);
  196. }
  197. $ids_arr = array();
  198. if( !empty($goods_ids_nohead_arr) )
  199. {
  200. foreach($goods_ids_nohead_arr as $val){
  201. $ids_arr[] = $val['id'];
  202. }
  203. }
  204. $ids_str = implode(',',$ids_arr);
  205. if( !empty($ids_str) )
  206. {
  207. $where .= " and g.id in ({$ids_str})";
  208. } else{
  209. $where .= " and 0 ";
  210. }
  211. }
  212. $where .= " and gc.begin_time <={$now_time} and gc.end_time > {$now_time} ";
  213. $where .= " and gc.is_new_buy=0 and gc.is_spike_buy = 0 ";
  214. $community_goods = D('Home/Pingoods')->get_community_index_goods('g.*,gc.begin_time,gc.end_time,gc.big_img,gc.is_take_fullreduction,gc.labelname,gc.video ', $where,$offset,$per_page);
  215. if( !empty($community_goods) )
  216. {
  217. $is_open_fullreduction = D('Home/Front')->get_config_by_name('is_open_fullreduction');
  218. $full_money = D('Home/Front')->get_config_by_name('full_money');
  219. $full_reducemoney = D('Home/Front')->get_config_by_name('full_reducemoney');
  220. $is_open_vipcard_buy = D('Home/Front')->get_config_by_name('is_open_vipcard_buy');
  221. $is_open_vipcard_buy = !empty($is_open_vipcard_buy) && $is_open_vipcard_buy == 1 ? 1:0;
  222. if(empty($full_reducemoney) || $full_reducemoney <= 0)
  223. {
  224. $is_open_fullreduction = 0;
  225. }
  226. $cart= D('Home/Car');
  227. $list = array();
  228. $copy_text_arr = array();
  229. foreach($community_goods as $val)
  230. {
  231. $tmp_data = array();
  232. $tmp_data['actId'] = $val['id'];
  233. $tmp_data['spuName'] = $val['goodsname'];
  234. $tmp_data['spuCanBuyNum'] = $val['total'];
  235. $tmp_data['spuDescribe'] = $val['subtitle'];
  236. $tmp_data['end_time'] = $val['end_time'];
  237. $tmp_data['is_take_vipcard'] = $val['is_take_vipcard'];
  238. $tmp_data['soldNum'] = $val['seller_count'] + $val['sales'];
  239. $productprice = $val['productprice'];
  240. $tmp_data['marketPrice'] = explode('.', $productprice);
  241. if( !empty($val['big_img']) )
  242. {
  243. $tmp_data['bigImg'] = tomedia($val['big_img']);
  244. }
  245. $good_image = D('Home/Pingoods')->get_goods_images($val['id']);
  246. if( !empty($good_image) )
  247. {
  248. $tmp_data['skuImage'] = tomedia($good_image['image']);
  249. }
  250. $price_arr = D('Home/Pingoods')->get_goods_price($val['id'], $member_id);
  251. $price = $price_arr['price'];
  252. if( $pageNum == 1 )
  253. {
  254. $copy_text_arr[] = array('goods_name' => $val['goodsname'], 'price' => $price);
  255. }
  256. $tmp_data['actPrice'] = explode('.', $price);
  257. $tmp_data['card_price'] = $price_arr['card_price'];
  258. //card_price
  259. $tmp_data['skuList']= D('Home/Pingoods')->get_goods_options($val['id'],$member_id);
  260. if( !empty($tmp_data['skuList']) )
  261. {
  262. $tmp_data['car_count'] = 0;
  263. }else{
  264. $car_count = $cart->get_wecart_goods($val['id'],"",$head_id ,$token);
  265. if( empty($car_count) )
  266. {
  267. $tmp_data['car_count'] = 0;
  268. }else{
  269. $tmp_data['car_count'] = $car_count;
  270. }
  271. }
  272. if($is_open_fullreduction == 0)
  273. {
  274. $tmp_data['is_take_fullreduction'] = 0;
  275. }else if($is_open_fullreduction == 1){
  276. $tmp_data['is_take_fullreduction'] = $val['is_take_fullreduction'];
  277. }
  278. // 商品角标
  279. $label_id = unserialize($val['labelname']);
  280. if($label_id){
  281. $label_info = D('Home/Pingoods')->get_goods_tags($label_id);
  282. if($label_info){
  283. if($label_info['type'] == 1){
  284. $label_info['tagcontent'] = tomedia($label_info['tagcontent']);
  285. } else {
  286. $label_info['len'] = mb_strlen($label_info['tagcontent'], 'utf-8');
  287. }
  288. }
  289. $tmp_data['label_info'] = $label_info;
  290. }
  291. $tmp_data['is_video'] = empty($val['video']) ? false : true;
  292. $list[] = $tmp_data;
  293. }
  294. $is_show_list_timer = D('Home/Front')->get_config_by_name('is_show_list_timer');
  295. $is_show_cate_tabbar = D('Home/Front')->get_config_by_name('is_show_cate_tabbar');
  296. echo json_encode(array('code' => 0, 'list' => $list ,'is_vip_card_member' => $is_vip_card_member,'copy_text_arr' => $copy_text_arr, 'cur_time' => time() ,'full_reducemoney' => $full_reducemoney,'full_money' => $full_money,'is_open_vipcard_buy' => $is_open_vipcard_buy,'is_open_fullreduction' => $is_open_fullreduction,'is_show_list_timer'=>$is_show_list_timer, 'cate_info' => $cate_info, 'is_show_cate_tabbar'=>$is_show_cate_tabbar ));
  297. die();
  298. }else{
  299. $is_show_cate_tabbar = D('Home/Front')->get_config_by_name('is_show_cate_tabbar');
  300. echo json_encode( array('code' => 1, 'cate_info' => $cate_info, 'is_show_cate_tabbar'=>$is_show_cate_tabbar) );
  301. die();
  302. }
  303. }
  304. /**
  305. 微信购买会员卡
  306. **/
  307. public function wxcharge()
  308. {
  309. $_GPC = I('request.');
  310. $token = $_GPC['token'];
  311. $weprogram_token = M('lionfish_comshop_weprogram_token')->field('member_id')->where( array('token' => $token) )->find();
  312. $member_id = $weprogram_token['member_id'];
  313. if( empty($member_id) )
  314. {
  315. echo json_encode( array('code' =>1,'msg' =>'未登录') );
  316. die();
  317. }
  318. $rech_id = isset($_GPC['rech_id']) && $_GPC['rech_id'] > 0 ? $_GPC['rech_id'] : 0;
  319. $card_info = M('lionfish_comshop_member_card')->where( array('id' => $rech_id ) )->find();
  320. if( empty($card_info) )
  321. {
  322. echo json_encode( array('code' =>1,'msg' =>'无此会员卡') );
  323. die();
  324. }
  325. $money = $card_info['price'];
  326. $member_info = M('lionfish_comshop_member')->where( array('member_id' => $member_id ) )->find();
  327. $now_time = time();
  328. $order_type = 1;
  329. if( $member_info['card_id'] >0 && $member_info['card_end_time'] > $now_time )
  330. {
  331. $order_type = 2;
  332. }else if( $member_info['card_id'] >0 && $member_info['card_end_time'] < $now_time ){
  333. $order_type = 3;
  334. }
  335. $member_charge_flow_data = array();
  336. $member_charge_flow_data['order_sn'] = build_order_no($member_id);
  337. $member_charge_flow_data['member_id'] = $member_id;
  338. $member_charge_flow_data['pay_type'] = 'weixin';
  339. $member_charge_flow_data['state'] = 0;
  340. $member_charge_flow_data['car_id'] = $card_info['id'];
  341. $member_charge_flow_data['expire_day'] = $card_info['expire_day'];
  342. $member_charge_flow_data['price'] = $card_info['price'];
  343. $member_charge_flow_data['order_type'] = $order_type; // 1,2,3
  344. $member_charge_flow_data['begin_time'] = 0;
  345. $member_charge_flow_data['end_time'] = 0;
  346. $member_charge_flow_data['pay_time'] = 0;
  347. $member_charge_flow_data['addtime'] = time();
  348. $order_id = M('lionfish_comshop_member_card_order')->add( $member_charge_flow_data );
  349. $shop_domain = D('Home/Front')->get_config_by_name('shop_domain');
  350. $fee = $money;
  351. $appid = D('Home/Front')->get_config_by_name('wepro_appid');
  352. $body = '会员卡购买';
  353. $mch_id = D('Home/Front')->get_config_by_name('wepro_partnerid');
  354. $nonce_str = nonce_str();
  355. $notify_url = $shop_domain.'/notify.php';
  356. $openid = $member_info['we_openid'];
  357. $out_trade_no = $order_id.'-'.time().'-buycard-'.$rech_id;
  358. $spbill_create_ip = $_SERVER['REMOTE_ADDR'];
  359. $total_fee = $fee*100;
  360. $trade_type = 'JSAPI';
  361. $pay_key = D('Home/Front')->get_config_by_name('wepro_key');
  362. $post['appid'] = $appid;
  363. $post['body'] = $body;
  364. $post['mch_id'] = $mch_id;
  365. $post['nonce_str'] = $nonce_str;
  366. $post['notify_url'] = $notify_url;
  367. $post['openid'] = $openid;
  368. $post['out_trade_no'] = $out_trade_no;
  369. $post['spbill_create_ip'] = $spbill_create_ip;
  370. $post['total_fee'] = $total_fee;
  371. $post['trade_type'] = $trade_type;
  372. $sign = sign($post,$pay_key);
  373. //sign()
  374. $post_xml = '<xml>
  375. <appid>'.$appid.'</appid>
  376. <body>'.$body.'</body>
  377. <mch_id>'.$mch_id.'</mch_id>
  378. <nonce_str>'.$nonce_str.'</nonce_str>
  379. <notify_url>'.$notify_url.'</notify_url>
  380. <openid>'.$openid.'</openid>
  381. <out_trade_no>'.$out_trade_no.'</out_trade_no>
  382. <spbill_create_ip>'.$spbill_create_ip.'</spbill_create_ip>
  383. <total_fee>'.$total_fee.'</total_fee>
  384. <trade_type>'.$trade_type.'</trade_type>
  385. <sign>'.$sign.'</sign>
  386. </xml> ';
  387. $url = 'https://api.mch.weixin.qq.com/pay/unifiedorder';
  388. $xml = http_request($url,$post_xml);
  389. $array = xml($xml);
  390. if($array['RETURN_CODE'] == 'SUCCESS' && $array['RESULT_CODE'] == 'SUCCESS'){
  391. $time = time();
  392. $tmp= array();
  393. $tmp['appId'] = $appid;
  394. $tmp['nonceStr'] = $nonce_str;
  395. $tmp['package'] = 'prepay_id='.$array['PREPAY_ID'];
  396. $tmp['signType'] = 'MD5';
  397. $tmp['timeStamp'] = "$time";
  398. M('lionfish_comshop_member_card_order')->where( array('id' => $order_id) )->save( array('formid' => $array['PREPAY_ID'] ) );
  399. $data['code'] = 0;
  400. $data['timeStamp'] = "$time";
  401. $data['nonceStr'] = $nonce_str;
  402. $data['signType'] = 'MD5';
  403. $data['package'] = 'prepay_id='.$array['PREPAY_ID'];
  404. $data['paySign'] = sign($tmp, $pay_key);
  405. $data['out_trade_no'] = $out_trade_no;
  406. $data['redirect_url'] = '../dan/me';
  407. }else{
  408. $data['code'] = 1;
  409. $data['text'] = "错误";
  410. $data['RETURN_CODE'] = $array['RETURN_CODE'];
  411. $data['RETURN_MSG'] = $array['RETURN_MSG'];
  412. }
  413. echo json_encode($data);
  414. die();
  415. }
  416. }