PHP語言開發Paypal支付demo的具體實現

若是咱們的應用是面向國際的、那麼支付的時候一般會考慮使用paypal。如下爲我的寫的一個paypal支付示例,已親測可行。paypal有個很不錯的地方就是爲開發者提供了sandbox(沙箱)測試功能。(即爲開發者在開發環境提供了一個虛擬的賣家帳戶和金額、以及一個虛擬的買家帳戶和金額、虛擬卡號等。可以讓咱們不用使用真實的金錢進行測試。)

1、開發前準備

  • https://developer.paypal.com/  到paypal的開發者官網註冊開發者帳號。
  • 用帳號登陸以後、點擊導航上面的 dashboard、進入dashboard面版。以下截圖、後續的操做都是在這個面板中操做。
  • 上面截圖中菜單 Sandbox下面的Accounts裏面能看到你的 sandbox測試的買家帳號和賣家帳號。2個測試帳號裏面都有profile選項裏面有changepassword能夠設置虛擬帳號的密碼。
  • 上面截圖中菜單Sandbox下面的Transactions就是你的交易記錄。
  • 點擊截圖頁面右上角的 Create App按鈕。建立一個應用。建立好後、會給你提供一個Client ID 和 Secret。這兩個能夠配置爲php常量後面開發中會用到。

2、進入支付Demo開發

  • 隨便在本地創建一個開發代碼根目錄、先創建一個index.html裏面就放一個簡單的產品名稱和產品價格兩個input項便可、代碼和截圖以下:
  • <!DOCTYPE html>
    <html lang="en">
        <head>
            <meta charset="utf-8">
            <title>支付頁面</title>
        </head>
        <body>
            <div>
                <form action="checkout.php" method="post" autocomplete="off">
                    <label for="item">
                        產品名稱
                        <input type="text" name="product">
                    </label>
                    <br>
                    <label for="amount">
                        價格
                        <input type="text" name="price">
                    </label>
                    <br>
                    <input type="submit" value="去付款">
                </form>
            </div>
        </body>
    </html>

  • 輸入產品名稱 和 價格。點擊去付款就會到paypal的付款頁面。用你的sandbox測試買家帳號去付款。就會發現付款成功。而後登錄你的測試賣家帳號。會發現賣家帳號已經收到付款。固然這裏會扣除paypal收取的手續費。手續費收的是賣家的。
  • 下面來具體看看php是怎麼實現的。首先先要把paypal提供的 php-sdk給弄到你的代碼目錄中來。這裏介紹使用php的包管理器composer來獲取最新sdk、固然你能夠能夠從github等其餘渠道獲取最新的paypal php-sdk。
  • 默認你的電腦已經安裝composer了。若是沒有本身去度娘或者google下composer安裝。
  • 而後在你的代碼根目錄寫一個composer.json文件來獲取包內容。json文件代碼以下:
    {
        "require" : {
            "paypal/rest-api-sdk-php" : "1.5.1"
        }
    }

    這裏若是是 linux/unix系統就直接再根目錄執行composer install來獲取包內容。php

  • 安裝好以後。根目錄下面會產生一個vendor目錄。裏面有composer 和 paypal兩個子目錄。composer裏面實現了自動加載、paypal則是你的sdk內容。
  • 接下來咱們來寫一個公共文件(這裏默認用 app/start.php、你的項目中能夠自定義)、其實裏面就只是實現了 sdk的autoload.php自動加載 和 建立剛纔上面的的client id  和 secret生成的paypal支付對象實例。start.php代碼以下:
  • <?php
    require "vendor/autoload.php"; //載入sdk的自動加載文件
    define('SITE_URL', 'http://www.paydemo.com'); //網站url自行定義
    //建立支付對象實例
    $paypal = new \PayPal\Rest\ApiContext(
        new \PayPal\Auth\OAuthTokenCredential(
            '你的Client ID'
            '你的secret'
        )
    );
  • 接下來就來實現表單中提交的處理文件 checkout.php。代碼內容以下:
  • <?php
    /**
     * @author xxxxxxxx
     * @brief 簡介:
     * @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; //運費
    
    $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("支付描述內容")
        ->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經過表單提交上來的參數對支付具體細節和參數進行初始化和設置。這裏只列出了經常使用的部分。paypal提供了不少參數設置。具體更豐富的能夠本身參考paypal官方開發者文檔。html

  • checkout.php設置完參數以後。會生成一個支付連接。用header跳轉到這個支付連接(就是paypal的支付頁面)到這個支付頁面上面就能夠用你的sandbox提供的buyer帳號去支付了。截圖以下:
  • 用buyer帳號支付完成以後。去看看你的sandbox的商家帳戶餘額吧。就會發現已經收到了扣除手續費外的錢了。
  • 這裏支付成功 或者 失敗後還有一個回調的處理。回調處理的php文件再上面的checkout.php裏面的setReturnUrl處設置。這裏設置的是/pay.php?success=true 
  • 接下來咱們來看看pay.php是怎麼簡單處理回調的。先貼上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 '支付成功!感謝支持!';

    好了。到這裏一個簡單的paypal支付的demo其實已經走通了。懂得支付原理以後、想要再你本身的項目裏面進行更豐富的擴展、就去paypal的官方文檔查看更多具體的開發項設置。包括交易明細的獲取等等都是能夠實現的。這裏就不具體講下去了。linux

本文中的demo是在 2015-9-2中 使用 最新的paypal php-sdk版本 1.5.1測試經過的。如sdk版本的相差較遠可能會有些許差異。

借閱者自行藉助參考便可!但願能給剛剛想要開發paypal支付、確無從入手的人帶來點幫助!

相關文章
相關標籤/搜索