url() . 'respond.php?code=' . $code; } /** * 取得某支付方式信息 * @param string $code 支付方式代码 */ function get_payment($code) { $sql = 'SELECT * FROM ' . $GLOBALS['ecs']->table('payment'). " WHERE pay_code = '$code' AND enabled = '1'"; $payment = $GLOBALS['db']->getRow($sql); if ($payment) { $config_list = unserialize($payment['pay_config']); foreach ($config_list AS $config) { $payment[$config['name']] = $config['value']; } } return $payment; } /** * 通过订单sn取得订单ID * @param string $order_sn 订单sn * @param blob $voucher 是否为会员充值 */ function get_order_id_by_sn($order_sn, $voucher = 'false') { if ($voucher == 'true') { if(is_numeric($order_sn)) { return $GLOBALS['db']->getOne("SELECT log_id FROM " . $GLOBALS['ecs']->table('pay_log') . " WHERE order_id=" . $order_sn . ' AND order_type=1'); } else { return ""; } } else { if(is_numeric($order_sn)) { $sql = 'SELECT order_id FROM ' . $GLOBALS['ecs']->table('order_info'). " WHERE order_sn = '$order_sn'"; $order_id = $GLOBALS['db']->getOne($sql); } if (!empty($order_id)) { $pay_log_id = $GLOBALS['db']->getOne("SELECT log_id FROM " . $GLOBALS['ecs']->table('pay_log') . " WHERE order_id='" . $order_id . "'"); return $pay_log_id; } else { return ""; } } } /** * 通过订单ID取得订单商品名称 * @param string $order_id 订单ID */ function get_goods_name_by_id($order_id) { $sql = 'SELECT goods_name FROM ' . $GLOBALS['ecs']->table('order_goods'). " WHERE order_id = '$order_id'"; $goods_name = $GLOBALS['db']->getCol($sql); return implode(',', $goods_name); } /** * 检查支付的金额是否与订单相符 * * @access public * @param string $log_id 支付编号 * @param float $money 支付接口返回的金额 * @return true */ function check_money($log_id, $money) { if(is_numeric($log_id)) { $sql = 'SELECT order_amount FROM ' . $GLOBALS['ecs']->table('pay_log') . " WHERE log_id = '$log_id'"; $amount = $GLOBALS['db']->getOne($sql); } else { return false; } if ($money == $amount) { return true; } else { return false; } } /** * 修改订单的支付状态 * * @access public * @param string $log_id 支付编号 * @param integer $pay_status 状态 * @param string $note 备注 * @return void */ function order_paid($log_id, $pay_status = PS_PAYED, $note = '') { /* 取得支付编号 */ $log_id = intval($log_id); if ($log_id > 0) { /* 取得要修改的支付记录信息 */ $sql = "SELECT * FROM " . $GLOBALS['ecs']->table('pay_log') . " WHERE log_id = '$log_id'"; $pay_log = $GLOBALS['db']->getRow($sql); if ($pay_log && $pay_log['is_paid'] == 0) { /* 修改此次支付操作的状态为已付款 */ $sql = 'UPDATE ' . $GLOBALS['ecs']->table('pay_log') . " SET is_paid = '1' WHERE log_id = '$log_id'"; $GLOBALS['db']->query($sql); /* 根据记录类型做相应处理 */ if ($pay_log['order_type'] == PAY_ORDER) { /* 取得订单信息 */ $sql = 'SELECT main_order_id, order_id, user_id, order_sn, consignee, address, tel, shipping_id, pay_status, extension_code, extension_id, goods_amount, ' . 'shipping_fee, insure_fee, pay_fee, tax, pack_fee, card_fee, surplus, money_paid, integral_money, bonus, order_amount, discount '. 'FROM ' . $GLOBALS['ecs']->table('order_info') . " WHERE order_id = '$pay_log[order_id]'"; $order = $GLOBALS['db']->getRow($sql); $main_order_id = $order['main_order_id']; $order_id = $order['order_id']; $order_sn = $order['order_sn']; //预售首先支付定金--无需分单 if($order['extension_code'] == 'presale'){ $money_paid = $order['money_paid'] + $order['order_amount']; if($order['pay_status'] == 0){ /* 修改订单状态为已部分付款 */ $order_amount= $order['goods_amount'] + $order['shipping_fee'] + $order['insure_fee'] + $order['pay_fee'] + $order['tax'] - $order['money_paid'] - $order['order_amount']; $sql = 'UPDATE ' . $GLOBALS['ecs']->table('order_info') . " SET order_status = '" . OS_CONFIRMED . "', " . " confirm_time = '" . gmtime() . "', " . " pay_status = '". PS_PAYED_PART ."', " . " pay_time = '".gmtime()."', " . " money_paid = '$money_paid'," . " order_amount = '$order_amount' ". "WHERE order_id = '$order_id'"; $GLOBALS['db']->query($sql); /* 记录订单操作记录 */ order_action($order_sn, OS_CONFIRMED, SS_UNSHIPPED, PS_PAYED_PART, $note, $GLOBALS['_LANG']['buyer']); //更新pay_log update_pay_log($order_id); }else{ $sql = 'UPDATE ' . $GLOBALS['ecs']->table('order_info') . " SET pay_status = '". PS_PAYED ."', " . " pay_time = '".gmtime()."', " . " money_paid = '$money_paid'," . " order_amount = 0 ". "WHERE order_id = '$order_id'"; $GLOBALS['db']->query($sql); /* 记录订单操作记录 */ order_action($order_sn, OS_CONFIRMED, SS_UNSHIPPED, PS_PAYED, $note, $GLOBALS['_LANG']['buyer']); } }else{ /* 修改订单状态为已付款 */ $sql = 'UPDATE ' . $GLOBALS['ecs']->table('order_info') . " SET order_status = '" . OS_CONFIRMED . "', " . " confirm_time = '" . gmtime() . "', " . " pay_status = '$pay_status', " . " pay_time = '".gmtime()."', " . " money_paid = money_paid + order_amount," . " order_amount = 0 ". "WHERE order_id = '$order_id'"; $GLOBALS['db']->query($sql); /* 记录订单操作记录 */ order_action($order_sn, OS_CONFIRMED, SS_UNSHIPPED, $pay_status, $note, $GLOBALS['_LANG']['buyer']); } /* 修改子订单状态为已付款 by wanganlin */ $sql = "SELECT COUNT(*) FROM ". $GLOBALS['ecs']->table('order_info') ." WHERE main_order_id = '$order_id'"; $child_num = $GLOBALS['db']->getOne($sql); if($main_order_id == 0 && $child_num > 0){ $sql = 'UPDATE ' . $GLOBALS['ecs']->table('order_info') . " SET order_status = '" . OS_CONFIRMED . "', " . " confirm_time = '" . gmtime() . "', " . " pay_status = '$pay_status', " . " pay_time = '".gmtime()."', " . " money_paid = order_amount," . " order_amount = 0 ". "WHERE main_order_id = '$order_id'"; $GLOBALS['db']->query($sql); $sql = 'SELECT order_sn ' . 'FROM ' . $GLOBALS['ecs']->table('order_info') . " WHERE main_order_id = '$order_id'"; $order_res = $GLOBALS['db']->getAll($sql); foreach ($order_res AS $row) { /* 记录订单操作记录 */ order_action($row['order_sn'], OS_CONFIRMED, SS_UNSHIPPED, $pay_status, $note, $GLOBALS['_LANG']['buyer']); } } /* 如果需要,发短信 */ $sql = "SELECT ru_id FROM ". $GLOBALS['ecs']->table('order_goods') ." WHERE order_id = '$order_id' LIMIT 1"; $ru_id = $GLOBALS['db']->getOne($sql); if($ru_id == 0){ $sms_shop_mobile = $GLOBALS['_CFG']['sms_shop_mobile']; }else{ $sql = "SELECT mobile FROM ". $GLOBALS['ecs']->table('seller_shopinfo') ." WHERE ru_id = '$ru_id'"; $sms_shop_mobile = $db->getOne($sql); } if ($GLOBALS['_CFG']['sms_order_payed'] == '1' && $sms_shop_mobile != '') { include_once(ROOT_PATH.'includes/cls_sms.php'); $sms = new sms(); $sms->send($sms_shop_mobile, sprintf($GLOBALS['_LANG']['order_payed_sms'], $order_sn, $order['consignee'], $order['tel']),'', 13,1); } /* 对虚拟商品的支持 */ $virtual_goods = get_virtual_goods($order_id); if (!empty($virtual_goods)) { $msg = ''; if (!virtual_goods_ship($virtual_goods, $msg, $order_sn, true)) { $GLOBALS['_LANG']['pay_success'] .= '