調起支付方法:
/**
* 跳向支付寶付款
* @param array $order 訂單數據 必須包含 out_trade_no(訂單號)、price(訂單金額)、subject(商品名稱標題)
*/
function alipay($order, $client = 'pc')
{
vendor('Alipay.AlipaySubmit', '', '.class.php');
// 獲取配置
$config = C('ALIPAY_CONFIG');
$data = array(
"_input_charset" => $config['input_charset'], // 編碼格式
/*"logistics_fee" => "0.00", */// 物流費用
/* "logistics_payment" => "SELLER_PAY",*/ // 物流支付方式SELLER_PAY(賣家承擔運費)、BUYER_PAY(買家承擔運費)
/* "logistics_type" => "EXPRESS",*/ // 物流類型EXPRESS(快遞)、POST(平郵)、EMS(EMS)
"notify_url" => $config['notify_url'], // 異步接收支付狀態通知的鏈接
"out_trade_no" => $order['out_trade_no'], // 訂單號
"partner" => $config['partner'], // partner 從支付寶商戶版個人中心獲取
"payment_type" => "1", // 支付類型對應請求時的 payment_type 參數,原樣返回。固定設置爲1即可
"total_fee" => $order['price'], // 訂單價格單位爲元
// "price" => 0.01, // // 調價用於測試
/* "quantity" => "1",*/ // price、quantity 能代替 total_fee。 即存在 total_fee,就不能存在 price 和 quantity;存在 price、quantity, 就不能存在 total_fee。 (沒繞明白;好吧;那無視這個參數即可)
/* "receive_address" => '1', // 收貨人地址 即時到賬方式無視此參數即可
"receive_mobile" => '1', // 收貨人手機號碼 即時到賬方式無視即可
"receive_name" => '1', // 收貨人姓名 即時到賬方式無視即可
"receive_zip" => '1', // 收貨人郵編 即時到賬方式無視即可*/
"return_url" => $config['return_url'], // 頁面跳轉 同步通知 頁面路徑 支付寶處理完請求後,當前頁面自 動跳轉到商戶網站裏指定頁面的 http 路徑。
// 'seller_id' => '2088421851231245',
'seller_id' => $config['partner'],
/* "seller_email" => $config['seller_email'],*/ // email 從支付寶商戶版個人中心獲取
// "service" => "create_direct_pay_by_user",
"service" => $client == 'wap' ? "alipay.wap.create.direct.pay.by.user" : "create_direct_pay_by_user",
// 接口名稱 固定設置爲create_direct_pay_by_user
"show_url" => $config['show_url'], // 商品展示網址,收銀臺頁面上,商品展示的超鏈接。
"subject" => $order['subject'], // 商品名稱商品的標題/交易標題/訂單標 題/訂單關鍵字等
);
// print_R($data);exit;
$alipay = new \AlipaySubmit($config);
if ($client == 'wap') {
$new = $alipay->buildRequestPara($data);
$go_pay = $alipay->buildRequestForm($new, 'get', '支付');
echo $go_pay;
} else {
$new = $alipay->buildRequestPara($data);
$go_pay = $alipay->buildRequestForm($new, 'get', '支付');
echo $go_pay;
}
}
參數構建類
<?php
/* *
* 類名:AlipaySubmit
* 功能:支付寶各接口請求提交類
* 詳細:構造支付寶各接口表單HTML文本,獲取遠程HTTP數據
* 版本:3.3
* 日期:2012-07-23
* 說明:
* 以下代碼只是爲了方便商戶測試而提供的樣例代碼,商戶可以根據自己網站的需要,按照技術文檔編寫,並非一定要使用該代碼。
* 該代碼僅供學習和研究支付寶接口使用,只是提供一個參考。
*/
require_once("alipay_core.function.php");
require_once("alipay_md5.function.php");
require_once("alipay_rsa.function.php");
header("Content-type:text/html;charset=utf-8");
class AlipaySubmit {
var $alipay_config;
/**
*支付寶網關地址(新)
*/
var $alipay_gateway_new = 'https://mapi.alipay.com/gateway.do?';
function __construct($alipay_config){
$this->alipay_config = $alipay_config;
}
function AlipaySubmit($alipay_config) {
$this->__construct($alipay_config);
}
/**
* 生成簽名結果
* @param $para_sort 已排序要簽名的數組
* return 簽名結果字符串
*/
function buildRequestMysign($para_sort) {
//把數組所有元素,按照“參數=參數值”的模式用“&”字符拼接成字符串
$prestr = createLinkstring($para_sort);
$mysign = "";
switch (strtoupper(trim($this->alipay_config['sign_type']))) {
case "MD5" :
$mysign = md5Sign($prestr, $this->alipay_config['key']);
break;
case "RSA" :
$mysign = rsaSign($prestr, $this->alipay_config['key']);
break;
default :
$mysign = "";
}
return $mysign;
}
/**
* 生成要請求給支付寶的參數數組
* @param $para_temp 請求前的參數數組
* @return 要請求的參數數組
*/
function buildRequestPara($para_temp) {
//除去待簽名參數數組中的空值和簽名參數
// p($para_temp);
$para_filter = paraFilter($para_temp);
// p($para_filter);die;
//對待簽名參數數組排序
$para_sort = argSort($para_filter);
//生成簽名結果
$mysign = $this->buildRequestMysign($para_sort);
//簽名結果與簽名方式加入請求提交參數組中
$para_sort['sign'] = $mysign;
$para_sort['sign_type'] = strtoupper(trim($this->alipay_config['sign_type']));
return $para_sort;
}
/**
* 生成要請求給支付寶的參數數組
* @param $para_temp 請求前的參數數組
* @return 要請求的參數數組字符串
*/
function buildRequestParaToString($para_temp) {
// p($para_temp);
//待請求參數數組
$para = $this->buildRequestPara($para_temp);
// p($para);
//把參數組中所有元素,按照“參數=參數值”的模式用“&”字符拼接成字符串,並對字符串做urlencode編碼
$request_data = createLinkstringUrlencode($para);
// echo $request_data;
return $request_data;
}
/**
* 建立請求,以表單HTML形式構造(默認)
* @param $para_temp 請求參數數組
* @param $method 提交方式。兩個值可選:post、get
* @param $button_name 確認按鈕顯示文字
* @return 提交表單HTML文本
*/
function buildRequestForm($para_temp, $method, $button_name) {
//待請求參數數組
$para = $this->buildRequestPara($para_temp);
$sHtml = "<form id='alipaysubmit' name='alipaysubmit' action='".$this->alipay_gateway_new."_input_charset=".trim(strtolower($this->alipay_config['input_charset']))."' method='".$method."'>";
while (list ($key, $val) = each ($para)) {
$sHtml.= "<input type='hidden' name='".$key."' value='".$val."'/>";
}
$sHtml=$sHtml.'</form>';
// echo $sHtml;die;
$sHtml = $sHtml."<script>document.forms['alipaysubmit'].submit();</script>";
return $sHtml;
}
/**
* 建立請求,以模擬遠程HTTP的POST請求方式構造並獲取支付寶的處理結果
* @param $para_temp 請求參數數組
* @return 支付寶處理結果
*/
function buildRequestHttp($para_temp) {
$sResult = '';
//待請求參數數組字符串
$request_data = $this->buildRequestPara($para_temp);
//遠程獲取數據
$sResult = getHttpResponsePOST($this->alipay_gateway_new, $this->alipay_config['cacert'],$request_data,trim(strtolower($this->alipay_config['input_charset'])));
p($request_data);die;
return $sResult;
}
/**
* 建立請求,以模擬遠程HTTP的POST請求方式構造並獲取支付寶的處理結果,帶文件上傳功能
* @param $para_temp 請求參數數組
* @param $file_para_name 文件類型的參數名
* @param $file_name 文件完整絕對路徑
* @return 支付寶返回處理結果
*/
function buildRequestHttpInFile($para_temp, $file_para_name, $file_name) {
//待請求參數數組
$para = $this->buildRequestPara($para_temp);
$para[$file_para_name] = "@".$file_name;
//遠程獲取數據
$sResult = getHttpResponsePOST($this->alipay_gateway_new, $this->alipay_config['cacert'],$para,trim(strtolower($this->alipay_config['input_charset'])));
return $sResult;
}
/**
* 用於防釣魚,調用接口query_timestamp來獲取時間戳的處理函數
* 注意:該功能PHP5環境及以上支持,因此必須服務器、本地電腦中裝有支持DOMDocument、SSL的PHP配置環境。建議本地調試時使用PHP開發軟件
* return 時間戳字符串
*/
function query_timestamp() {
$url = $this->alipay_gateway_new."service=query_timestamp&partner=".trim(strtolower($this->alipay_config['partner']))."&_input_charset=".trim(strtolower($this->alipay_config['input_charset']));
$encrypt_key = "";
$doc = new DOMDocument();
$doc->load($url);
$itemEncrypt_key = $doc->getElementsByTagName( "encrypt_key" );
$encrypt_key = $itemEncrypt_key->item(0)->nodeValue;
return $encrypt_key;
}
}
?>