You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

206 lines
7.3 KiB

3 years ago
<?php
defined('BASE_PATH') OR exit('No direct script access allowed');
class alipay
{
/**
* 生成支付代码
* @param array $order 订单信息
* @param array $payment 支付方式信息
*/
public function get_code($order, $payment)
{
if (! defined('CHARSET')) {
$charset = 'utf-8';
} else {
$charset = CHARSET;
}
include_once(BASE_PATH.'helpers/payment_helper.php');
$gateway = 'http://wappaygw.alipay.com/service/rest.htm?';
// 请求业务数据
$req_data = '<direct_trade_create_req>' .
'<subject>' . $order['order_sn'] . '</subject>' .
'<out_trade_no>' . $order['order_sn'] . 'O' . $order['log_id'] . '</out_trade_no>' .
'<total_fee>' . $order['order_amount'] . '</total_fee>' .
'<seller_account_name>' . $payment['alipay_account'] . '</seller_account_name>' .
'<call_back_url>' . return_url(basename(__FILE__, '.php')) . '</call_back_url>' .
'<notify_url>' . __URL__.'alipay.php' . '</notify_url>' .
'<out_user>' . $order['consignee'] . '</out_user>' .
'<merchant_url>'.__URL__.'</merchant_url>' .
'<pay_expire>3600</pay_expire>' .
'</direct_trade_create_req>';
$parameter = array(
'service' => 'alipay.wap.trade.create.direct', // 接口名称
'format' => 'xml', // 请求参数格式
'v' => '2.0', // 接口版本号
'partner' => $payment['alipay_partner'], // 合作者身份ID
'req_id' => $order['order_sn'] . $order['log_id'], // 请求号,唯一
'sec_id' => 'MD5', // 签名方式
'req_data' => $req_data, // 请求业务数据
"_input_charset" => $charset
);
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) . $payment['alipay_key'];
// 请求授权接口
$result = \libraries\Http::doPost($gateway, $param . '&sign=' . md5($sign));
$result = urldecode($result); // URL转码
$result_array = explode('&', $result); // 根据 & 符号拆分
// 重构数组
$new_result_array = $temp_item = array();
if (is_array($result_array)) {
foreach ($result_array as $vo) {
$temp_item = explode('=', $vo, 2); // 根据 & 符号拆分
$new_result_array[$temp_item[0]] = $temp_item[1];
}
}
$xml = simplexml_load_string($new_result_array['res_data']);
$request_token = (array) $xml->request_token;
// 请求交易接口
$parameter = array(
'service' => 'alipay.wap.auth.authAndExecute', // 接口名称
'format' => 'xml', // 请求参数格式
'v' => $new_result_array['v'], // 接口版本号
'partner' => $new_result_array['partner'], // 合作者身份ID
'sec_id' => $new_result_array['sec_id'],
'req_data' => '<auth_and_execute_req><request_token>' . $request_token[0] . '</request_token></auth_and_execute_req>',
'request_token' => $request_token[0],
'_input_charset' => $charset
);
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) . $payment['alipay_key'];
/* 生成支付按钮 */
$button = '<script type="text/javascript" src="data/assets/script/ap.js"></script><a type="button" class="box-flex btn-submit" onclick="javascript:_AP.pay(\'' . $gateway . $param . '&sign=' . md5($sign) . '\')">支付宝支付</a>';
return $button;
}
/**
* 同步通知
* @param $data
* @return mixed
*/
public function callback($data)
{
if (! empty($_GET)) {
include_once(BASE_PATH.'helpers/payment_helper.php');
$out_trade_no = explode('O', $_GET['out_trade_no']);
$log_id = $out_trade_no[1];
$payment = get_payment($data['code']);
/* 检查数字签名是否正确 */
ksort($_GET);
reset($_GET);
$sign = '';
foreach ($_GET as $key => $val) {
if ($key != 'sign' && $key != 'sign_type' && $key != 'code') {
$sign .= "$key=$val&";
}
}
$sign = substr($sign, 0, - 1) . $payment['alipay_key'];
if (md5($sign) != $_GET['sign']) {
return false;
}
if ($_GET['result'] == 'success') {
/* 改变订单状态 */
order_paid($log_id, 2);
return true;
} else {
return false;
}
}else{
return false;
}
}
/**
* 异步通知
* @param $data
* @return mixed
*/
public function notify($data)
{
if (! empty($_POST)) {
include_once(BASE_PATH.'helpers/payment_helper.php');
$payment = get_payment($data['code']);
// 支付宝系统通知待签名数据构造规则比较特殊,为固定顺序。
$parameter['service'] = $_POST['service'];
$parameter['v'] = $_POST['v'];
$parameter['sec_id'] = $_POST['sec_id'];
$parameter['notify_data'] = $_POST['notify_data'];
// 生成签名字符串
$sign = '';
foreach ($parameter as $key => $val) {
$sign .= "$key=$val&";
}
$sign = substr($sign, 0, - 1) . $payment['alipay_key'];
// 验证签名
if (md5($sign) != $_POST['sign']) {
exit("fail");
}
// 解析notify_data
$data = (array) simplexml_load_string($parameter['notify_data']);
// 交易状态
$trade_status = $data['trade_status'];
// 获取支付订单号log_id
$out_trade_no = explode('O', $data['out_trade_no']);
$log_id = $out_trade_no[1]; // 订单号log_id
if ($trade_status == 'TRADE_FINISHED' || $trade_status == 'TRADE_SUCCESS') {
/* 改变订单状态 */
order_paid($log_id, 2);
/*if(method_exists('WechatController', 'do_oauth')){
//如果需要,微信通知
$order_id = model()->table('order_info')->field('order_id')->where(array('order_sn'=>$out_trade_no[0]))->one();
$order_url = U('user/order/detail', array('order_id'=>$order_id), true);
$order_url = urlencode(base64_encode($order_url));
//send_wechat_message('pay_remind', '', $out_trade_no[0].' 订单已支付', $order_url, $out_trade_no[0]);
}*/
exit("success");
} else {
exit("fail");
}
} else {
exit("fail");
}
}
/**
* 订单查询
* @return mixed
*/
public function query($order, $payment)
{
}
}