284 lines
7.4 KiB
PHP
Executable File
284 lines
7.4 KiB
PHP
Executable File
<?php
|
|
namespace wstmart\home\controller;
|
|
use wstmart\common\model\Payments as M;
|
|
use wstmart\common\model\Orders as OM;
|
|
use wstmart\common\model\LogMoneys as LM;
|
|
use wstmart\common\model\ChargeItems as CM;
|
|
/**
|
|
* ============================================================================
|
|
* 阿里支付控制器
|
|
*/
|
|
class Alipays extends Base{
|
|
|
|
/**
|
|
* 初始化
|
|
*/
|
|
private $aliPayConfig;
|
|
public function _initialize() {
|
|
$this->aliPayConfig = array();
|
|
$m = new M();
|
|
$this->aliPayConfig = $m->getPayment("alipays");
|
|
}
|
|
|
|
/**
|
|
* 生成支付代码
|
|
*/
|
|
function getAlipaysUrl(){
|
|
$payObj = input("payObj/s");
|
|
$m = new OM();
|
|
$obj = array();
|
|
$data = array();
|
|
$orderAmount = 0;
|
|
$out_trade_no = "";
|
|
$extra_common_param = "";
|
|
$subject = "";
|
|
$body = "";
|
|
if($payObj=="recharge"){//充值
|
|
$itmeId = (int)input("itmeId/d");
|
|
$orderAmount = 0;
|
|
if($itmeId>0){
|
|
$cm = new CM();
|
|
$item = $cm->getItemMoney($itmeId);
|
|
$orderAmount = isSet($item["chargeMoney"])?$item["chargeMoney"]:0;
|
|
}else{
|
|
$orderAmount = (int)input("needPay/d");
|
|
}
|
|
|
|
$shopId = (int)session('WST_USER.shopId');
|
|
$targetType = ($shopId>0)?1:0;
|
|
$targetId = (int)session('WST_USER.userId');
|
|
if($targetType==1){//商家
|
|
$targetId = $shopId;
|
|
}
|
|
$data["status"] = $orderAmount>0?1:-1;
|
|
$out_trade_no = WSTOrderNo();
|
|
$extra_common_param = $payObj."@".$targetId."@".$targetType."@".$itmeId;
|
|
$subject = '钱包充值 ¥'.$orderAmount.'元';
|
|
$body = '钱包充值';
|
|
}else{
|
|
$obj["orderNo"] = input("orderNo/s");
|
|
$obj["isBatch"] = (int)input("isBatch/d");
|
|
$data = $m->checkOrderPay($obj);
|
|
if($data["status"]==1){
|
|
$userId = (int)session('WST_USER.userId');
|
|
$obj["userId"] = $userId;
|
|
$order = $m->getPayOrders($obj);
|
|
$orderAmount = $order["needPay"];
|
|
$payRand = $order["payRand"];
|
|
$out_trade_no = $obj["orderNo"]."a".$payRand;
|
|
$extra_common_param = $payObj."@".$userId."@".$obj["isBatch"];
|
|
$subject = '支付购买商品费用'.$orderAmount.'元';
|
|
$body = '支付订单费用';
|
|
}
|
|
}
|
|
|
|
if($data["status"]==1){
|
|
$return_url = url("home/alipays/response","",true,true);
|
|
$notify_url = url("home/alipays/aliNotify","",true,true);
|
|
$parameter = array(
|
|
'extra_common_param'=> $extra_common_param,
|
|
'service' => 'create_direct_pay_by_user',
|
|
'partner' => $this->aliPayConfig['parterID'],
|
|
'_input_charset' => "utf-8",
|
|
'notify_url' => $notify_url,
|
|
'return_url' => $return_url,
|
|
/* 业务参数 */
|
|
'subject' => $subject,
|
|
'body' => $body,
|
|
'out_trade_no' => $out_trade_no,
|
|
'total_fee' => $orderAmount,
|
|
'quantity' => 1,
|
|
'payment_type' => 1,
|
|
/* 物流参数 */
|
|
'logistics_type' => 'EXPRESS',
|
|
'logistics_fee' => 0,
|
|
'logistics_payment' => 'BUYER_PAY_AFTER_RECEIVE',
|
|
/* 买卖双方信息 */
|
|
'seller_email' => $this->aliPayConfig['payAccount']
|
|
);
|
|
ksort($parameter);
|
|
reset($parameter);
|
|
$param = '';
|
|
$sign = '';
|
|
foreach ($parameter AS $key => $val){
|
|
$param .= "$key=" .urlencode($val). "&";
|
|
$sign .= "$key=$val&";
|
|
}
|
|
$param = substr($param, 0, -1);
|
|
$sign = substr($sign, 0, -1). $this->aliPayConfig['parterKey'];
|
|
$url = 'https://mapi.alipay.com/gateway.do?'.$param. '&sign='.md5($sign).'&sign_type=MD5';
|
|
$data["url"] = $url;
|
|
}
|
|
|
|
return $data;
|
|
}
|
|
|
|
/**
|
|
* 支付结果同步回调
|
|
*/
|
|
function response(){
|
|
$m = new OM();
|
|
$request = $_GET;
|
|
unset($request['_URL_']);
|
|
$payRes = self::notify($request);
|
|
if($payRes['status']){
|
|
$extras = explode("@",$_GET['extra_common_param']);
|
|
if($extras[0]=="recharge"){//充值
|
|
if($extras[2]==1){
|
|
$this->redirect(url("home/logmoneys/shopmoneys"));
|
|
}else{
|
|
$this->redirect(url("home/logmoneys/usermoneys"));
|
|
}
|
|
}else{
|
|
$this->redirect(url("home/alipays/paysuccess"));
|
|
}
|
|
}else{
|
|
$this->error('支付失败');
|
|
}
|
|
}
|
|
|
|
/**
|
|
* 支付结果异步回调
|
|
*/
|
|
function aliNotify(){
|
|
$m = new OM();
|
|
$request = $_POST;
|
|
$payRes = self::notify($request);
|
|
if($payRes['status']){
|
|
|
|
$extras = explode("@",$_POST['extra_common_param']);
|
|
$rs = array();
|
|
if($extras[0]=="recharge"){//充值
|
|
$targetId = (int)$extras [1];
|
|
$targetType = (int)$extras [2];
|
|
$itemId = (int)$extras [3];
|
|
$obj = array ();
|
|
$obj["trade_no"] = $_POST['trade_no'];
|
|
$obj["out_trade_no"] = $_POST["out_trade_no"];;
|
|
$obj["targetId"] = $targetId;
|
|
$obj["targetType"] = $targetType;
|
|
$obj["itemId"] = $itemId;
|
|
$obj["total_fee"] = $_POST['total_fee'];
|
|
$obj["payFrom"] = 'alipays';
|
|
// 支付成功业务逻辑
|
|
$m = new LM();
|
|
$rs = $m->complateRecharge ( $obj );
|
|
}else{
|
|
//商户订单号
|
|
$obj = array();
|
|
$tradeNo = explode("a",$_POST['out_trade_no']);
|
|
$obj["trade_no"] = $_POST['trade_no'];
|
|
$obj["out_trade_no"] = $tradeNo[0];
|
|
$obj["total_fee"] = $_POST['total_fee'];
|
|
|
|
$obj["userId"] = $extras[1];
|
|
$obj["isBatch"] = $extras[2];
|
|
$obj["payFrom"] = 'alipays';
|
|
//支付成功业务逻辑
|
|
$rs = $m->complatePay($obj);
|
|
}
|
|
|
|
if($rs["status"]==1){
|
|
echo 'success';
|
|
}else{
|
|
echo 'fail';
|
|
}
|
|
}else{
|
|
echo 'fail';
|
|
}
|
|
}
|
|
|
|
/**
|
|
* 支付回调接口
|
|
*/
|
|
function notify($request){
|
|
$returnRes = array('info'=>'','status'=>false);
|
|
$request = $this->argSort($request);
|
|
// 检查数字签名是否正确
|
|
$isSign = $this->getSignVeryfy($request);
|
|
if (!$isSign){//签名验证失败
|
|
$returnRes['info'] = '签名验证失败';
|
|
return $returnRes;
|
|
}
|
|
if ($request['trade_status'] == 'TRADE_SUCCESS' || $request['trade_status'] == 'TRADE_FINISHED'){
|
|
$returnRes['status'] = true;
|
|
}
|
|
return $returnRes;
|
|
}
|
|
|
|
/**
|
|
* 获取返回时的签名验证结果
|
|
*/
|
|
function getSignVeryfy($para_temp) {
|
|
$parterKey = $this->aliPayConfig["parterKey"];
|
|
//除去待签名参数数组中的空值和签名参数
|
|
$para_filter = $this->paraFilter($para_temp);
|
|
//对待签名参数数组排序
|
|
$para_sort = $this->argSort($para_filter);
|
|
//把数组所有元素,按照“参数=参数值”的模式用“&”字符拼接成字符串
|
|
$prestr = $this->createLinkstring($para_sort);
|
|
|
|
$isSgin = false;
|
|
$isSgin = $this->md5Verify($prestr, $para_temp['sign'], $parterKey);
|
|
return $isSgin;
|
|
}
|
|
|
|
/**
|
|
* 验证签名
|
|
*/
|
|
function md5Verify($prestr, $sign, $key) {
|
|
$prestr = $prestr . $key;
|
|
$mysgin = md5($prestr);
|
|
if($mysgin == $sign) {
|
|
return true;
|
|
}else {
|
|
return false;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* 把数组所有元素,按照“参数=参数值”的模式用“&”字符拼接成字符串
|
|
*/
|
|
function createLinkstring($para) {
|
|
$arg = "";
|
|
while (list ($key, $val) = each ($para)) {
|
|
$arg.=$key."=".$val."&";
|
|
}
|
|
//去掉最后一个&字符
|
|
$arg = substr($arg,0,count($arg)-2);
|
|
//如果存在转义字符,那么去掉转义
|
|
if(get_magic_quotes_gpc()){$arg = stripslashes($arg);}
|
|
|
|
return $arg;
|
|
}
|
|
|
|
/**
|
|
* 除去数组中的空值和签名参数
|
|
*/
|
|
function paraFilter($para) {
|
|
$para_filter = array();
|
|
while (list ($key, $val) = each ($para)) {
|
|
if($key == "sign" || $key == "sign_type" || $val == "")continue;
|
|
else $para_filter[$key] = $para[$key];
|
|
}
|
|
return $para_filter;
|
|
}
|
|
|
|
/**
|
|
* 对数组排序
|
|
*/
|
|
function argSort($para) {
|
|
ksort($para);
|
|
reset($para);
|
|
return $para;
|
|
}
|
|
|
|
/**
|
|
* 检查支付结果
|
|
*/
|
|
public function paySuccess() {
|
|
return $this->fetch('order_pay_step3');
|
|
}
|
|
|
|
}
|