PHP對(duì)接支付寶支付的時(shí)候,異步回調(diào)和同步回調(diào)是非常重要的功能,用于確認(rèn)支付結(jié)果和更新訂單狀態(tài)。本文將詳細(xì)介紹異步回調(diào)和同步回調(diào)的作用,并提供具體的案例代碼。
一、異步回調(diào)的作用
異步回調(diào)(也稱為服務(wù)器通知)是支付寶支付過(guò)程中最重要的一步,主要用于確認(rèn)支付結(jié)果。當(dāng)用戶支付成功后,支付寶服務(wù)器會(huì)向商戶服務(wù)器發(fā)送一個(gè)HTTP POST請(qǐng)求,通知支付結(jié)果。商戶服務(wù)器接收到該回調(diào)消息后,需要驗(yàn)證消息的合法性,確認(rèn)支付結(jié)果,并更新訂單狀態(tài)。
具體步驟如下:
- 商戶服務(wù)器接收到支付寶服務(wù)器發(fā)送的異步回調(diào)請(qǐng)求,并獲取請(qǐng)求參數(shù)。
- 驗(yàn)證參數(shù)的合法性。通過(guò)驗(yàn)簽方式,校驗(yàn)請(qǐng)求參數(shù)是否被篡改。商戶需要將請(qǐng)求參數(shù)按照一定的規(guī)則進(jìn)行加密,并將加密結(jié)果與支付寶提供的公鑰進(jìn)行比對(duì),以確定參數(shù)的真實(shí)性和完整性。
- 驗(yàn)證通過(guò)后,商戶服務(wù)器處理回調(diào)請(qǐng)求,包括更新訂單狀態(tài)、發(fā)送郵件通知等。
- 商戶服務(wù)器將處理結(jié)果返回給支付寶服務(wù)器。需要返回一個(gè)字符串 "success",表示接收成功。如果不返回或者返回其他字符串,支付寶服務(wù)器會(huì)間隔一段時(shí)間內(nèi)重復(fù)發(fā)送回調(diào)請(qǐng)求。
- 通過(guò)異步回調(diào),商戶服務(wù)器可以確保支付結(jié)果的真實(shí)性,及時(shí)更新訂單狀態(tài),避免訂單的丟失或錯(cuò)誤。異步回調(diào)是支付過(guò)程中必不可少的一環(huán),它的主要作用是與支付寶服務(wù)器進(jìn)行雙向通信,確認(rèn)支付結(jié)果,并進(jìn)行后續(xù)處理。
具體案例代碼如下:
<?php
// 驗(yàn)證參數(shù)的合法性
function verifySign($params, $publicKey) {
$sign = $params['sign']; // 簽名參數(shù)
unset($params['sign']); // 剔除簽名參數(shù)
ksort($params); // 按照參數(shù)名進(jìn)行升序排序
$data = '';
foreach ($params as $key => $value) {
$data .= $key . '=' . $value . '&';
}
$data = rtrim($data, '&');
// 使用openssl_verify函數(shù)驗(yàn)簽
$result = openssl_verify($data, base64_decode($sign), $publicKey, OPENSSL_ALGO_SHA256);
return $result == 1;
}
// 更新訂單狀態(tài)
function updateOrderStatus($orderNo, $status) {
// 更新訂單狀態(tài)的邏輯代碼
}
// 處理支付寶異步回調(diào)請(qǐng)求
function handleAlipayNotify() {
$params = $_POST; // 獲取回調(diào)參數(shù)
$publicKey = '支付寶提供的公鑰';
// 驗(yàn)證參數(shù)的合法性
if (verifySign($params, $publicKey)) {
// 驗(yàn)簽通過(guò)
$orderNo = $params['out_trade_no']; // 商戶訂單號(hào)
$tradeStatus = $params['trade_status']; // 支付狀態(tài)
if ($tradeStatus == 'TRADE_SUCCESS') {
// 支付成功,更新訂單狀態(tài)為已支付
updateOrderStatus($orderNo, 'paid');
}
echo 'success'; // 返回接收成功的標(biāo)識(shí)
} else {
// 驗(yàn)簽失敗,可能存在安全風(fēng)險(xiǎn)
echo 'fail'; // 返回接收失敗的標(biāo)識(shí)
}
}
// 入口函數(shù)
handleAlipayNotify();
?>
二、同步回調(diào)的作用
同步回調(diào)(也稱為前臺(tái)通知)的主要作用是給用戶展示支付結(jié)果頁(yè)面。當(dāng)用戶支付成功后,支付寶會(huì)跳轉(zhuǎn)回商戶指定的同步回調(diào)地址,攜帶支付結(jié)果參數(shù)。商戶服務(wù)器接收到該回調(diào)后,需要驗(yàn)證參數(shù)的合法性,并根據(jù)支付結(jié)果展示對(duì)應(yīng)的頁(yè)面。
具體步驟如下:
- 商戶服務(wù)器接收到支付寶跳轉(zhuǎn)的同步回調(diào)請(qǐng)求,并獲取請(qǐng)求參數(shù)。
- 驗(yàn)證參數(shù)的合法性。通過(guò)驗(yàn)簽方式,校驗(yàn)請(qǐng)求參數(shù)是否被篡改,確保參數(shù)的真實(shí)性和完整性。
- 需要判斷支付結(jié)果的具體狀態(tài),根據(jù)支付狀態(tài)展示對(duì)應(yīng)的頁(yè)面,如支付成功頁(yè)面、支付失敗頁(yè)面等。
- 同步回調(diào)通常用于展示支付結(jié)果給用戶查看,不作為最終支付結(jié)果的判斷依據(jù)。因?yàn)橥交卣{(diào)是在前端完成的,可能會(huì)被偽造或篡改。驗(yàn)證參數(shù)的合法性只是為了避免被惡意攻擊,不能作為支付結(jié)果的唯一判斷依據(jù)。
具體案例代碼如下:
<?php
// 驗(yàn)證參數(shù)的合法性
function verifySign($params, $publicKey) {
$sign = $params['sign']; // 簽名參數(shù)
unset($params['sign']); // 剔除簽名參數(shù)
ksort($params); // 按照參數(shù)名進(jìn)行升序排序
$data = '';
foreach ($params as $key => $value) {
$data .= $key . '=' . $value . '&';
}
$data = rtrim($data, '&');
// 使用openssl_verify函數(shù)驗(yàn)簽
$result = openssl_verify($data, base64_decode($sign), $publicKey, OPENSSL_ALGO_SHA256);
return $result == 1;
}
// 處理支付寶同步回調(diào)請(qǐng)求
function handleAlipayReturn() {
$params = $_GET; // 獲取回調(diào)參數(shù)
$publicKey = '支付寶提供的公鑰';
// 驗(yàn)證參數(shù)的合法性
if (verifySign($params, $publicKey)) {
// 驗(yàn)簽通過(guò)
$tradeStatus = $params['trade_status']; // 支付狀態(tài)
if ($tradeStatus == 'TRADE_SUCCESS') {
// 支付成功,展示支付成功頁(yè)面
echo '支付成功!';
} else {
// 支付失敗,展示支付失敗頁(yè)面
echo '支付失?。?;
}
} else {
// 驗(yàn)簽失敗,可能存在安全風(fēng)險(xiǎn)
echo '驗(yàn)簽失??!';
}
}
// 入口函數(shù)
handleAlipayReturn();
?>
總結(jié)
以上是PHP對(duì)接支付寶支付時(shí)異步回調(diào)和同步回調(diào)的具體作用以及案例代碼。異步回調(diào)用于確認(rèn)支付結(jié)果和更新訂單狀態(tài),同步回調(diào)用于展示支付結(jié)果給用戶查看。通過(guò)驗(yàn)證參數(shù)的合法性,可以確保支付結(jié)果的真實(shí)性和完整性,避免安全風(fēng)險(xiǎn)。在實(shí)際開發(fā)中,需要根據(jù)具體業(yè)務(wù)需求,結(jié)合支付寶提供的接口文檔,進(jìn)行相應(yīng)的編碼和調(diào)試。