2019-09-06 23:53:10 +08:00

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');
}
}