PHP語(yǔ)言開(kāi)發(fā)Paypal支付demo的具體實(shí)現(xiàn)
一、開(kāi)發(fā)前準(zhǔn)備
https://developer.paypal.com/ 到paypal的開(kāi)發(fā)者官網(wǎng)注冊(cè)開(kāi)發(fā)者賬號(hào)。
用賬號(hào)登錄之后、點(diǎn)擊導(dǎo)航上面的 dashboard、進(jìn)入dashboard面版。如下截圖、后續(xù)的操作都是在這個(gè)面板中操作。
上面截圖中菜單 Sandbox下面的Accounts里面能看到你的 sandbox測(cè)試的買(mǎi)家賬號(hào)和賣(mài)家賬號(hào)。2個(gè)測(cè)試賬號(hào)里面都有profile選項(xiàng)里面有changepassword可以設(shè)置虛擬賬號(hào)的密碼。
上面截圖中菜單Sandbox下面的Transactions就是你的交易記錄。
點(diǎn)擊截圖頁(yè)面右上角的 Create App按鈕。創(chuàng)建一個(gè)應(yīng)用。創(chuàng)建好后、會(huì)給你提供一個(gè)Client ID 和 Secret。這兩個(gè)可以配置為php常量后面開(kāi)發(fā)中會(huì)用到。
二、進(jìn)入支付Demo開(kāi)發(fā)
隨便在本地建立一個(gè)開(kāi)發(fā)代碼根目錄、先建立一個(gè)index.html里面就放一個(gè)簡(jiǎn)單的產(chǎn)品名稱和產(chǎn)品價(jià)格兩個(gè)input項(xiàng)即可、代碼和截圖如下:
- DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="utf-8">
- <title>支付頁(yè)面title>
- head>
- <body>
- <div>
- <form action="checkout.php" method="post" autocomplete="off">
- <label for="item">
- 產(chǎn)品名稱
- <input type="text" name="product">
- label>
- <br>
- <label for="amount">
- 價(jià)格
- <input type="text" name="price">
- label>
- <br>
- <input type="submit" value="去付款">
- form>
- div>
- body>
- html>
輸入產(chǎn)品名稱 和 價(jià)格。點(diǎn)擊去付款就會(huì)到paypal的付款頁(yè)面。用你的sandbox測(cè)試買(mǎi)家賬號(hào)去付款。就會(huì)發(fā)現(xiàn)付款成功。然后登陸你的測(cè)試賣(mài)家賬號(hào)。會(huì)發(fā)現(xiàn)賣(mài)家賬號(hào)已經(jīng)收到付款。當(dāng)然這里會(huì)扣除paypal收取的手續(xù)費(fèi)。手續(xù)費(fèi)收的是賣(mài)家的。
下面來(lái)具體看看php是怎么實(shí)現(xiàn)的。首先先要把paypal提供的 php-sdk給弄到你的代碼目錄中來(lái)。這里介紹使用php的包管理器composer來(lái)獲取***sdk、當(dāng)然你可以可以從github等其他渠道獲取***的paypal php-sdk。
默認(rèn)你的電腦已經(jīng)安裝composer了。如果沒(méi)有自己去度娘或者google下composer安裝。
然后在你的代碼根目錄寫(xiě)一個(gè)composer.json文件來(lái)獲取包內(nèi)容。json文件代碼如下:
{
"require" : { "paypal/rest-api-sdk-php" : "1.5.1"
}
}
這里如果是 linux/unix系統(tǒng)就直接再根目錄執(zhí)行composer install來(lái)獲取包內(nèi)容。
安裝好之后。根目錄下面會(huì)產(chǎn)生一個(gè)vendor目錄。里面有composer 和 paypal兩個(gè)子目錄。composer里面實(shí)現(xiàn)了自動(dòng)加載、paypal則是你的sdk內(nèi)容。
接 下來(lái)我們來(lái)寫(xiě)一個(gè)公共文件(這里默認(rèn)用 app/start.php、你的項(xiàng)目中可以自定義)、其實(shí)里面就只是實(shí)現(xiàn)了 sdk的autoload.php自動(dòng)加載 和 創(chuàng)建剛才上面的的client id 和 secret生成的paypal支付對(duì)象實(shí)例。start.php代碼如下:
require "vendor/autoload.php"; //載入sdk的自動(dòng)加載文件 define('SITE_URL', 'http://www.paydemo.com'); //網(wǎng)站url自行定義 //創(chuàng)建支付對(duì)象實(shí)例 $paypal = new \PayPal\Rest\ApiContext( new \PayPal\Auth\OAuthTokenCredential( '你的Client ID' '你的secret'
)
);
接下來(lái)就來(lái)實(shí)現(xiàn)表單中提交的處理文件 checkout.php。代碼內(nèi)容如下:
/**
* @author xxxxxxxx
* @brief 簡(jiǎn)介:
* @date 15/9/2
* @time 下午5:00
*/
use \PayPal\Api\Payer;
use \PayPal\Api\Item;
use \PayPal\Api\ItemList;
use \PayPal\Api\Details;
use \PayPal\Api\Amount;
use \PayPal\Api\Transaction;
use \PayPal\Api\RedirectUrls;
use \PayPal\Api\Payment;
use \PayPal\Exception\PayPalConnectionException;
require "app/start.php"; if (!isset($_POST['product'], $_POST['price'])) { die("lose some params"); } $product = $_POST['product']; $price = $_POST['price']; $shipping = 2.00; //運(yùn)費(fèi) $total = $price + $shipping; $payer = new Payer(); $payer->setPaymentMethod('paypal'); $item = new Item(); $item->setName($product) ->setCurrency('USD') ->setQuantity(1) ->setPrice($price); $itemList = new ItemList(); $itemList->setItems([$item]); $details = new Details(); $details->setShipping($shipping) ->setSubtotal($price); $amount = new Amount(); $amount->setCurrency('USD') ->setTotal($total) ->setDetails($details); $transaction = new Transaction(); $transaction->setAmount($amount) ->setItemList($itemList) ->setDescription("支付描述內(nèi)容") ->setInvoiceNumber(uniqid()); $redirectUrls = new RedirectUrls(); $redirectUrls->setReturnUrl(SITE_URL . '/pay.php?success=true') ->setCancelUrl(SITE_URL . '/pay.php?success=false'); $payment = new Payment(); $payment->setIntent('sale') ->setPayer($payer) ->setRedirectUrls($redirectUrls) ->setTransactions([$transaction]); try { $payment->create($paypal); } catch (PayPalConnectionException $e) { echo $e->getData(); die(); } $approvalUrl = $payment->getApprovalLink(); header("Location: {$approvalUrl}");
checkout.php通過(guò)表單提交上來(lái)的參數(shù)對(duì)支付具體細(xì)節(jié)和參數(shù)進(jìn)行初始化和設(shè)置。這里只列出了常用的部分。paypal提供了很多參數(shù)設(shè)置。具體更豐富的可以自己參考paypal官方開(kāi)發(fā)者文檔。
checkout.php設(shè)置完參數(shù)之后。會(huì)生成一個(gè)支付鏈接。用header跳轉(zhuǎn)到這個(gè)支付鏈接(就是paypal的支付頁(yè)面)到這個(gè)支付頁(yè)面上面就可以用你的sandbox提供的buyer賬號(hào)去支付了。截圖如下:
用buyer賬號(hào)支付完成之后。去看看你的sandbox的商家賬戶余額吧。就會(huì)發(fā)現(xiàn)已經(jīng)收到了扣除手續(xù)費(fèi)外的錢(qián)了。
這里支付成功 或者 失敗后還有一個(gè)回調(diào)的處理?;卣{(diào)處理的php文件再上面的checkout.php里面的setReturnUrl處設(shè)置。這里設(shè)置的是/pay.php?success=true
接下來(lái)我們來(lái)看看pay.php是怎么簡(jiǎn)單處理回調(diào)的。先貼上pay.php的代碼:
php
require 'app/start.php';
use PayPal\Api\Payment;
use PayPal\Api\PaymentExecution;
if(!isset($_GET['success'], $_GET['paymentId'], $_GET['PayerID'])){
die();
}
if((bool)$_GET['success']=== 'false'){
echo 'Transaction cancelled!';
die();
}
$paymentID = $_GET['paymentId'];
$payerId = $_GET['PayerID'];
$payment = Payment::get($paymentID, $paypal);
$execute = new PaymentExecution();
$execute->setPayerId($payerId);
try{
$result = $payment->execute($execute, $paypal);
}catch(Exception $e){
die($e);
}
echo '支付成功!感謝支持!';
好了。到這里一個(gè)簡(jiǎn)單的paypal支付的demo其實(shí)已經(jīng)走通了。懂得支付原理之后、想要再你自己的項(xiàng)目里面進(jìn)行更豐富的擴(kuò)展、就去paypal的官方文檔查看更多具體的開(kāi)發(fā)項(xiàng)設(shè)置。包括交易明細(xì)的獲取等等都是可以實(shí)現(xiàn)的。這里就不具體講下去了。