<?php
/**
* 支付入口
*
*
**by 好商城V3 www.33hao.com 二次开发修正授权运营版*/
defined('InShopNC') or exit('Access Invalid!');
class paymentControl extends BaseHomeControl{
public function __construct() {
//向前兼容
$_GET['extra_common_param'] = str_replace(array('predeposit','product_buy'),array('pd_order','real_order'),$_GET['extra_common_param']);
$_POST['extra_common_param'] = str_replace(array('predeposit','product_buy'),array('pd_order','real_order'),$_POST['extra_common_param']);
}
/**
* 实物商品订单
*/
public function real_orderOp(){
$pay_sn = $_POST['pay_sn'];
$payment_code = $_POST['payment_code'];
$url = 'index.php?act=member_order';
if(!preg_match('/^\d{18}$/',$pay_sn)){
showMessage('参数错误','','html','error');
}
$logic_payment = Logic('payment');
$result = $logic_payment->getPaymentInfo($payment_code);
if(!$result['state']) {
showMessage($result['msg'], $url, 'html', 'error');
}
$payment_info = $result['data'];
//计算所需支付金额等支付单信息
$result = $logic_payment->getRealOrderInfo($pay_sn, $_SESSION['member_id']);
if(!$result['state']) {
showMessage($result['msg'], $url, 'html', 'error');
}
if ($result['data']['api_pay_state'] || empty($result['data']['api_pay_amount'])) {
showMessage('该订单不需要支付', $url, 'html', 'error');
}
//转到第三方API支付
$this->_api_pay($result['data'], $payment_info);
}
/**
* 虚拟商品购买
*/
public function vr_orderOp(){
$order_sn = $_POST['order_sn'];
$payment_code = $_POST['payment_code'];
$url = 'index.php?act=member_vr_order';
if(!preg_match('/^\d{18}$/',$order_sn)){
showMessage('参数错误','','html','error');
}
$logic_payment = Logic('payment');
$result = $logic_payment->getPaymentInfo($payment_code);
if(!$result['state']) {
showMessage($result['msg'], $url, 'html', 'error');
}
$payment_info = $result['data'];
//计算所需支付金额等支付单信息
$result = $logic_payment->getVrOrderInfo($order_sn, $_SESSION['member_id']);
if(!$result['state']) {
showMessage($result['msg'], $url, 'html', 'error');
}
if ($result['data']['order_state'] != ORDER_STATE_NEW || empty($result['data']['api_pay_amount'])) {
showMessage('该订单不需要支付', $url, 'html', 'error');
}
//转到第三方API支付
$this->_api_pay($result['data'], $payment_info);
}
/**
* 预存款充值
*/
public function pd_orderOp(){
$pdr_sn = $_POST['pdr_sn'];
$payment_code = $_POST['payment_code'];
$url = 'index.php?act=predeposit';
if(!preg_match('/^\d{18}$/',$pdr_sn)){
showMessage('参数错误',$url,'html','error');
}
$logic_payment = Logic('payment');
$result = $logic_payment->getPaymentInfo($payment_code);
if(!$result['state']) {
showMessage($result['msg'], $url, 'html', 'error');
}
$payment_info = $result['data'];
$result = $logic_payment->getPdOrderInfo($pdr_sn,$_SESSION['member_id']);
if(!$result['state']) {
showMessage($result['msg'], $url, 'html', 'error');
}
if ($result['data']['pdr_payment_state'] || empty($result['data']['api_pay_amount'])) {
showMessage('该充值单不需要支付', $url, 'html', 'error');
}
//转到第三方API支付
$this->_api_pay($result['data'], $payment_info);
}
/**
* 第三方在线支付接口
*
*/
private function _api_pay($order_info, $payment_info) {
$payment_api = new $payment_info['payment_code']($payment_info,$order_info);
if($payment_info['payment_code'] == 'chinabank') {
$payment_api->submit();
} else {
@header("Location: ".$payment_api->get_payurl());
}
exit();
}
/**
* 通知处理(支付宝异步通知和网银在线自动对账)
*
*/
public function notifyOp(){
switch ($_GET['payment_code']) {
case 'alipay':
$success = 'success'; $fail = 'fail'; break;
case 'chinabank':
$success = 'ok'; $fail = 'error'; break;
default:
exit();
}
$order_type = $_POST['extra_common_param'];
$out_trade_no = $_POST['out_trade_no'];
$trade_no = $_POST['trade_no'];
//参数判断
if(!preg_match('/^\d{18}$/',$out_trade_no)) exit($fail);
$model_pd = Model('predeposit');
$logic_payment = Logic('payment');
if ($order_type == 'real_order') {
$result = $logic_payment->getRealOrderInfo($out_trade_no);
if (intval($result['data']['api_pay_state'])) {
exit($success);
}
$order_list = $result['data']['order_list'];
} elseif ($order_type == 'vr_order'){
$result = $logic_payment->getVrOrderInfo($out_trade_no);
if ($result['data']['order_state'] != ORDER_STATE_NEW) {
exit($success);
}
} elseif ($order_type == 'pd_order') {
$result = $logic_payment->getPdOrderInfo($out_trade_no);
if ($result['data']['pdr_payment_state'] == 1) {
exit($success);
}
} else {
exit();
}
$order_pay_info = $result['data'];
//取得支付方式
$result = $logic_payment->getPaymentInfo($_GET['payment_code']);
if (!$result['state']) {
exit($fail);
}
$payment_info = $result['data'];
//创建支付接口对象
$payment_api = new $payment_info['payment_code']($payment_info,$order_pay_info);
//对进入的参数进行远程数据判断
$verify = $payment_api->notify_verify();
if (!$verify) {
exit($fail);
}
//购买商品
if ($order_type == 'real_order') {
$result = $logic_payment->updateRealOrder($out_trade_no, $payment_info['payment_code'], $order_list, $trade_no);
} elseif($order_type == 'vr_order'){
$result = $logic_payment->updateVrOrder($out_trade_no, $payment_info['payment_code'], $order_pay_info, $trade_no);
} elseif ($order_type == 'pd_order') {
$result = $logic_payment->updatePdOrder($out_trade_no,$trade_no,$payment_info,$order_pay_info);
}
exit($result['state'] ? $success : $fail);
}
/**
* 支付接口返回
*
*/
public function returnOp(){
$order_type = $_GET['extra_common_param'];
if ($order_type == 'real_order') {
$act = 'member_order';
} elseif($order_type == 'vr_order') {
$act = 'member_vr_order';
} elseif($order_type == 'pd_order') {
$act = 'predeposit';
} else {
exit();
}
$out_trade_no = $_GET['out_trade_no'];
$trade_no = $_GET['trade_no'];
$url = SHOP_SITE_URL.'/index.php?act='.$act;
//对外部交易编号进行非空判断
if(!preg_match('/^\d{18}$/',$out_trade_no)) {
showMessage('参数错误',$url,'','html','error');
}
$logic_payment = Logic('payment');
if ($order_type == 'real_order') {
$result = $logic_payment->getRealOrderInfo($out_trade_no);
if(!$result['state']) {
showMessage($result['msg'], $url, 'html', 'error');
}
if ($result['data']['api_pay_state']) {
$payment_state = 'success';
}
$order_list = $result['data']['order_list'];
}elseif ($order_type == 'vr_order') {
$result = $logic_payment->getVrOrderInfo($out_trade_no);
if(!$result['state']) {
showMessage($result['msg'], $url, 'html', 'error');
}
if ($result['data']['order_state'] != ORDER_STATE_NEW) {
$payment_state = 'success';
}
} elseif ($order_type == 'pd_order') {
$result = $logic_payment->getPdOrderInfo($out_trade_no);
if(!$result['state']) {
showMessage($result['msg'], $url, 'html', 'error');
}
if ($result['data']['pdr_payment_state'] == 1) {
$payment_state = 'success';
}
}
$order_pay_info = $result['data'];
$api_pay_amount = $result['data']['api_pay_amount'];
if ($payment_state != 'success') {
//取得支付方式
$result = $logic_payment->getPaymentInfo($_GET['payment_code']);
if (!$result['state']) {
showMessage($result['msg'],$url,'html','error');
}
$payment_info = $result['data'];
//创建支付接口对象
$payment_api = new $payment_info['payment_code']($payment_info,$order_pay_info);
//返回参数判断
$verify = $payment_api->return_verify();
if(!$verify) {
showMessage('支付数据验证失败',$url,'html','error');
}
//取得支付结果
$pay_result = $payment_api->getPayResult($_GET);
if (!$pay_result) {
showMessage('非常抱歉,您的订单支付没有成功,请您后尝试',$url,'html','error');
}
//更改订单支付状态
if ($order_type == 'real_order') {
$result = $logic_payment->updateRealOrder($out_trade_no, $payment_info['payment_code'], $order_list, $trade_no);
} else if($order_type == 'vr_order') {
$result = $logic_payment->updateVrOrder($out_trade_no, $payment_info['payment_code'], $order_pay_info, $trade_no);
} else if ($order_type == 'pd_order') {
$result = $logic_payment->updatePdOrder($out_trade_no, $trade_no, $payment_info, $order_pay_info);
}
if (!$result['state']) {
showMessage('支付状态更新失败',$url,'html','error');
}
}
//支付成功后跳转
if ($order_type == 'real_order') {
$pay_ok_url = SHOP_SITE_URL.'/index.php?act=buy&op=pay_ok&pay_sn='.$out_trade_no.'&pay_amount='.ncPriceFormat($api_pay_amount);
} elseif ($order_type == 'vr_order') {
$pay_ok_url = SHOP_SITE_URL.'/index.php?act=buy_virtual&op=pay_ok&order_sn='.$out_trade_no.'&order_id='.$order_pay_info['order_id'].'&order_amount='.ncPriceFormat($api_pay_amount);
} elseif ($order_type == 'pd_order') {
$pay_ok_url = SHOP_SITE_URL.'/index.php?act=predeposit';
}
if ($payment_info['payment_code'] == 'tenpay') {
showMessage('',$pay_ok_url,'tenpay');
} else {
redirect($pay_ok_url);
}
}
}
code
原创lixiao1290 ©著作权
©著作权归作者所有:来自51CTO博客作者lixiao1290的原创作品,请联系作者获取转载授权,否则将追究法律责任
下一篇:php
提问和评论都可以,用心的回复会被更多人看到
评论
发布评论
相关文章