支付寶即時到帳接口開發 - DEMO講解

支付寶即時到賬接口php

環境要求

PHP5.0以上,且須要開啓curl、openssl。 
文檔地址: 
https://doc.open.alipay.com/doc2/detail?treeId=62&articleId=103566&docType=1html

支付寶網頁即時到帳功能,可以讓用戶在線向開發者的支付寶帳號支付資金,交易資金即時到帳,幫助開發者快速回籠資金。 
交易步驟少,簡單、方便。 
交易資金三個月內可退款,提高買家購物保障。web

有2個demo: 
即時到帳交易接口(create_direct_pay_by_user)(DEMO下載) 
即時到帳批量退款有密接口(refund_fastpay_by_platform_pwd)(DEMO下載)api

咱們主要學習即時到帳交易接口(create_direct_pay_by_user)數組

電商網站支付流程圖

 

這裏寫圖片描述

選擇demo

即時到帳交易接口(create_direct_pay_by_user) demo下載解壓以後目錄以下圖: 
這裏寫圖片描述安全

選擇:MD5簽名版本/create_direct_pay_by_user-PHP-UTF-8 
這裏寫圖片描述服務器

咱們把這些文件放到,web目錄pay下,而後訪問:http://localhost/pay/ 
這裏寫圖片描述
點擊『確認支付』,^_^ 
這裏寫圖片描述curl

1.編輯alipay.config.php異步

//↓↓↓↓↓↓↓↓↓↓請在這裏配置您的基本信息↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓
//合做身份者ID,簽約帳號,以2088開頭由16位純數字組成的字符串,查看地址:https://b.alipay.com/order/pidAndKey.htm
$alipay_config['partner'] = '';函數

//收款支付寶帳號,以2088開頭由16位純數字組成的字符串,通常狀況下收款帳號就是簽約帳號
$alipay_config['seller_id'] = $alipay_config['partner'];

// MD5密鑰,安全檢驗碼,由數字和字母組成的32位字符串,查看地址:https://b.alipay.com/order/pidAndKey.htm
$alipay_config['key'] = '';

// 服務器異步通知頁面路徑 需http://格式的完整路徑,不能加?id=123這類自定義參數,必須外網能夠正常訪問
$alipay_config['notify_url'] = "http://商戶網址/create_direct_pay_by_user-PHP-UTF-8/notify_url.php";

// 頁面跳轉同步通知頁面路徑 需http://格式的完整路徑,不能加?id=123這類自定義參數,必須外網能夠正常訪問
$alipay_config['return_url'] = "http://商戶網址/create_direct_pay_by_user-PHP-UTF-8/return_url.php";

//簽名方式
$alipay_config['sign_type'] = strtoupper('MD5');

//字符編碼格式 目前支持 gbk 或 utf-8
$alipay_config['input_charset']= strtolower('utf-8');

//ca證書路徑地址,用於curl中ssl校驗
//請保證cacert.pem文件在當前文件夾目錄中
$alipay_config['cacert'] = getcwd().'\\cacert.pem';

//訪問模式,根據本身的服務器是否支持ssl訪問,若支持請選擇https;若不支持請選擇http
$alipay_config['transport'] = 'http';

// 支付類型 ,無需修改
$alipay_config['payment_type'] = "1";

// 產品類型,無需修改
$alipay_config['service'] = "create_direct_pay_by_user";

//↑↑↑↑↑↑↑↑↑↑請在這裏配置您的基本信息↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑


//↓↓↓↓↓↓↓↓↓↓ 請在這裏配置防釣魚信息,若是沒開通防釣魚功能,爲空便可 ↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓

// 防釣魚時間戳 若要使用請調用類文件submit中的query_timestamp函數
$alipay_config['anti_phishing_key'] = "";

// 客戶端的IP地址 非局域網的外網IP地址,如:221.0.0.1
$alipay_config['exter_invoke_ip'] = "";

//↑↑↑↑↑↑↑↑↑↑請在這裏配置防釣魚信息,若是沒開通防釣魚功能,爲空便可 ↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑

在上面的配置中,咱們就單單填寫好$alipay_config['partner'] 和$alipay_config['key']這2項後(注意必須是簽約商家的配置信息) 
這樣咱們『確認支付』會跳轉到http://www.mydev.com/alipayapi.php,而後跳轉到支付寶的支付頁面。

當你支付完成之後,會發送同步通知,跳回

// 頁面跳轉同步通知頁面路徑 需http://格式的完整路徑,不能加?id=123這類自定義參數,必須外網能夠正常訪問
$alipay_config['return_url'] = "http://商戶網址/create_direct_pay_by_user-PHP-UTF-8/return_url.php";

不定時的異步通知(若是同步通知成功,就不發異步通知了)

// 服務器異步通知頁面路徑 需http://格式的完整路徑,不能加?id=123這類自定義參數,必須外網能夠正常訪問
$alipay_config['notify_url'] = "http://商戶網址/create_direct_pay_by_user-PHP-UTF-8/notify_url.php";

2.demo流程總結 
第一步:在index.php中,構建訂單信息表單,有如下幾個字段

WIDout_trade_no     商戶訂單號
WIDsubject              商品名稱
WIDtotal_fee           付款金額
WIDbody                 商品描述

第二步:表單提交到alipayapi.php, 在alipayapi.php接收參數

/**************************請求參數**************************/
//商戶訂單號,商戶網站訂單系統中惟一訂單號,必填
$out_trade_no = $_POST['WIDout_trade_no'];

//訂單名稱,必填
$subject = $_POST['WIDsubject'];

//付款金額,必填
$total_fee = $_POST['WIDtotal_fee'];

//商品描述,可空
$body = $_POST['WIDbody'];

而後構建請求支付寶的參數:

//構造要請求的參數數組,無需改動
$parameter = array(
"service" => $alipay_config['service'],
"partner" => $alipay_config['partner'],
"seller_id" => $alipay_config['seller_id'],
"payment_type" => $alipay_config['payment_type'],
"notify_url" => $alipay_config['notify_url'],
"return_url" => $alipay_config['return_url'],

"anti_phishing_key"=>$alipay_config['anti_phishing_key'],
"exter_invoke_ip"=>$alipay_config['exter_invoke_ip'],
"out_trade_no" => $out_trade_no,
"subject" => $subject,
"total_fee" => $total_fee,
"body" => $body,
"_input_charset" => trim(strtolower($alipay_config['input_charset']))
//其餘業務參數根據在線開發文檔,添加參數.文檔地址:https://doc.open.alipay.com/doc2/detail.htm?spm=a219a.7629140.0.0.kiX33I&treeId=62&articleId=103740&docType=1
//如"參數名"=>"參數值"

);

而後發送請求(給支付寶),就跳轉到支付寶的支付頁面

//創建請求
$alipaySubmit = new AlipaySubmit($alipay_config);
$html_text = $alipaySubmit->buildRequestForm($parameter,"get", "確認");
echo $html_text;

第三步:支付完成同步通知(return_url.php)給網站,不定時異步通知(notify_url.php)給網站。

return_url.php或者notify_url.php,都是處理驗證結果

 

//計算得出通知驗證結果
$alipayNotify = new AlipayNotify($alipay_config);
$verify_result = $alipayNotify->verifyReturn();
if($verify_result) {//驗證成功
/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
//請在這裏加上商戶的業務邏輯程序代碼

//——請根據您的業務邏輯來編寫程序(如下代碼僅做參考)——
//獲取支付寶的通知返回參數,可參考技術文檔中頁面跳轉同步通知參數列表

//商戶訂單號

$out_trade_no = $_GET['out_trade_no'];

//支付寶交易號

$trade_no = $_GET['trade_no'];

//交易狀態
$trade_status = $_GET['trade_status'];


if($_GET['trade_status'] == 'TRADE_FINISHED' || $_GET['trade_status'] == 'TRADE_SUCCESS') {
//判斷該筆訂單是否在商戶網站中已經作過處理
//若是沒有作過處理,根據訂單號(out_trade_no)在商戶網站的訂單系統中查到該筆訂單的詳細,並執行商戶的業務程序
//若是有作過處理,不執行商戶的業務程序
}
else {
echo "trade_status=".$_GET['trade_status'];
}

echo "驗證成功<br />";

//——請根據您的業務邏輯來編寫程序(以上代碼僅做參考)——

/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
}
else {
//驗證失敗
//如要調試,請看alipay_notify.php頁面的verifyReturn函數
echo "驗證失敗";
}

 

通知客戶,你的訂單支付成功/失敗。 結束整個支付流程。

相關文章
相關標籤/搜索