Browse Source

test

master
用户名 3 years ago
parent
commit
d5e5bc078d
  1. 220
      mobile/dalianpay/demo/pay.php
  2. 18
      mobile/plugins/payment/wxpay.php

220
mobile/dalianpay/demo/pay.php

@ -1,122 +1,126 @@
<?php
session_start();
$openid = $_SESSION['openid'];
$redirect_url = $_SESSION['prev_url'];
// var_dump($redirect_url);
// 加载基础类
require_once('../library/Base.php');
$Base = new Base();
// 获取配置信息
$config = $Base->getConfig();
// var_dump('<pre>', $config);
function pay()
{
session_start();
$openid = $_SESSION['openid'];
$redirect_url = $_SESSION['prev_url'];
// unset($_SESSION['prev_url']);
// var_dump($redirect_url);
// 接口URL(测试)
$api_url = $config['pay_url'];
// $api_url = $_POST['url'];
$message = array(
"url"=>$api_url,
);
// echo json_encode($message,true);
// 加个body字段传中文试试
// 加载基础类
require_once('../library/Base.php');
$Base = new Base();
// 组装交易报文
$reqsn_prefix = date('Ymd');
// var_dump("uniq_id(reqsn)");
// echo "\r\n";
// var_dump(uniqid($reqsn_prefix));
$trade_data = array(
'orgid' => $config['org_num'],
'cusid' => $config['cusid'],
'branchno' => $config['branchno'],
'termcode' => $config['termcode'],
'version' => $config['version'],
'trxamt' => '1',
'reqsn' => uniqid($reqsn_prefix),
'producp' => 'JX0002',
'transtype' => 'JSP511',
'paytype' => 'W02',
'randomstr' => md5( uniqid() ),
'body' => 'pages',
'acct' => $openid,
);
// 获取配置信息
$config = $Base->getConfig();
// var_dump('<pre>', $config);
// 生成签名
$sign = $Base->Crypt->makeSign($trade_data);
if($sign === false)
{
// echo $Base->Crypt->err_msg;
$errorMessage = array(
"data"=>"makeSign error..."
// 接口URL(测试)
$api_url = $config['pay_url'];
// $api_url = $_POST['url'];
$message = array(
"url"=>$api_url,
);
return json_encode($errorMessage,true);
die();
}
// echo "\r\n";
// echo "[sign]: {$sign}";
// die();
// echo json_encode($message,true);
// 加个body字段传中文试试
// 加密交易报文
$crypted_trade_data = $Base->Crypt->encryptTradeData($trade_data);
if($crypted_trade_data === false)
{
// echo $Base->Crypt->err_msg;
$errorMessage = array(
"data"=>"encryptTradeData error..."
// 组装交易报文
$reqsn_prefix = date('Ymd');
// var_dump("uniq_id(reqsn)");
// echo "\r\n";
// var_dump(uniqid($reqsn_prefix));
$trade_data = array(
'orgid' => $config['org_num'],
'cusid' => $config['cusid'],
'branchno' => $config['branchno'],
'termcode' => $config['termcode'],
'version' => $config['version'],
'trxamt' => '1',
'reqsn' => uniqid($reqsn_prefix),
'producp' => 'JX0002',
'transtype' => 'JSP511',
'paytype' => 'W02',
'randomstr' => md5( uniqid() ),
'body' => 'pages',
'acct' => $openid,
);
return json_encode($errorMessage,true);
die();
}
// echo "\r\n";
// echo "[crypted message]: {$crypted_trade_data}";
// die();
// 发送报文
// echo "\r\n";
// var_dump($api_url);
$response = $Base->Request->send($api_url, $crypted_trade_data, $sign);
if($response === false)
{
// echo $Base->Request->err_msg;
$errorMessage = array(
"data"=>"send error..."
);
return json_encode($errorMessage,true);
die();
}
// echo "\r\n";
// echo "[response message]: {$response}";
// 生成签名
$sign = $Base->Crypt->makeSign($trade_data);
if($sign === false)
{
// echo $Base->Crypt->err_msg;
$errorMessage = array(
"data"=>"makeSign error..."
);
return json_encode($errorMessage,true);
die();
}
// echo "\r\n";
// echo "[sign]: {$sign}";
// die();
// 解析响应报文
$response = json_decode($response, true);
$response_data_crypted = $response['data'];
$response_sign = $response['sign'];
// echo "\r\n";
// echo "[response sign]: {$response_sign}";
// echo "\r\n";
// echo "[response data (ciphertext)]: {$response_data_crypted}";
// 加密交易报文
$crypted_trade_data = $Base->Crypt->encryptTradeData($trade_data);
if($crypted_trade_data === false)
{
// echo $Base->Crypt->err_msg;
$errorMessage = array(
"data"=>"encryptTradeData error..."
);
return json_encode($errorMessage,true);
die();
}
// echo "\r\n";
// echo "[crypted message]: {$crypted_trade_data}";
// die();
// 解密响应密文
$response_data = $Base->Crypt->decryptTradeData($response_data_crypted);
if($response_data === false)
{
// echo $Base->Crypt->err_msg;
$errorMessage = array(
"data"=>"decryptTradeData error..."
);
return json_encode($errorMessage,true);
die();
}
// echo "\r\n";
// echo "[response data(clear text)]: {$response_data}";
// die();
echo $response_data;
$_SESSION['response_data_json'] = $response_data;
// 发送报文
// echo "\r\n";
// var_dump($api_url);
$response = $Base->Request->send($api_url, $crypted_trade_data, $sign);
if($response === false)
{
// echo $Base->Request->err_msg;
$errorMessage = array(
"data"=>"send error..."
);
return json_encode($errorMessage,true);
die();
}
// echo "\r\n";
// echo "[response message]: {$response}";
// 解析响应报文
$response = json_decode($response, true);
$response_data_crypted = $response['data'];
$response_sign = $response['sign'];
// echo "\r\n";
// echo "[response sign]: {$response_sign}";
// echo "\r\n";
// echo "[response data (ciphertext)]: {$response_data_crypted}";
// 调回之前的地址
// header("Location: $redirect_url");
// exit;
// 解密响应密文
$response_data = $Base->Crypt->decryptTradeData($response_data_crypted);
if($response_data === false)
{
// echo $Base->Crypt->err_msg;
$errorMessage = array(
"data"=>"decryptTradeData error..."
);
return json_encode($errorMessage,true);
die();
}
// echo "\r\n";
// echo "[response data(clear text)]: {$response_data}";
// die();
echo $response_data;
$_SESSION['response_data_json'] = $response_data;
return $response_data;
// 调回之前的地址
// header("Location: $redirect_url");
// exit;
}
?>

18
mobile/plugins/payment/wxpay.php

@ -198,14 +198,16 @@ class wxpay
}
// 访问大连支付接口
$url = "https://$_SERVER[HTTP_HOST]$_SERVER[REQUEST_URI]";
var_dump($url);
$_SESSION['prev_url'] = $url;
var_dump($_SESSION['prev_url']);
header('Location: https://shop.heavenk.com/mobile/dalianpay/demo/pay.php');
// header('Location: https://www.baidu.com');
exit; // 终止当前脚本的执行,确保页面跳转生效
// $url = "https://$_SERVER[HTTP_HOST]$_SERVER[REQUEST_URI]";
// var_dump($url);
// $_SESSION['prev_url'] = $url;
// var_dump($_SESSION['prev_url']);
// header('Location: https://shop.heavenk.com/mobile/dalianpay/demo/pay.php');
// // header('Location: https://www.baidu.com');
// exit; // 终止当前脚本的执行,确保页面跳转生效
require_once('../../demo/pay.php');
$response_data = pay();
echo $response_data;
// 处理dalianpay统一支付接口传回的参数
// $_SESSION['response_data_json']

Loading…
Cancel
Save