因為公司的業(yè)務(wù)是H5平臺的,所以這里只介紹H5方案的接入說明。PayPal提供了豐富的和支付相關(guān)的能力,但是我公司的業(yè)務(wù)僅僅需要普通的一次性消耗付款,所以其它如訂閱等功能我也沒去了解,就不介紹了。還有注冊賬號的基本操作這里也不講了,在PayPal官網(wǎng)按步驟操作即可。我們從創(chuàng)建開發(fā)者應(yīng)用講起。
創(chuàng)新互聯(lián)自2013年起,先為潤州等服務(wù)建站,潤州等地企業(yè),進行企業(yè)商務(wù)咨詢服務(wù)。為潤州企業(yè)網(wǎng)站制作PC+手機+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問題。
點擊 打開PayPal開發(fā)者中心,國內(nèi)環(huán)境打開稍微有點滿,耐心等待一下。打開后登陸注冊好的賬號,進入 開發(fā)者后臺 ,在【My apps credentials】頁面中選擇 sandbox 選項卡創(chuàng)建一個沙箱應(yīng)用,創(chuàng)建好后可以獲得clientID和Secret。記錄下這兩個值,我們后面要用到。
最后可以給這個應(yīng)用可以設(shè)置webhook,即觸發(fā)某個事件(如完成付款)后,PayPal服務(wù)器通過此地址通知你。
因為我是H5平臺接入,所有有兩種方案可以選擇,一種是REST API,一種是Javascript SDK方案。
REST API方案:從服務(wù)端向PayPal服務(wù)器下單,下單完成后PayPal返回訂單ID和支付鏈接,將支付鏈接傳遞給前端用戶,用戶跳轉(zhuǎn)到PayPal的支付鏈接付款完成后,會通過跳轉(zhuǎn)回你下單時設(shè)置的目的地址,如果你有在PayPal后臺設(shè)置對應(yīng)事件的webhook的話,PayPal服務(wù)器也會通知你用戶已付款。然后你再去PayPal服務(wù)器確認訂單,確認完成后即完成了整個流程。
Javascript SDK方案:前端頁面加載PayPal JS資源,渲染支付按鈕,用戶點擊按鈕PayPal SDK自動下單并打開支付頁面,用戶支付完成后前端返回支付結(jié)果,如果你有在PayPal后臺設(shè)置對應(yīng)事件的webhook的話,PayPal服務(wù)器也會通知你用戶已付款。然后你再去PayPal服務(wù)器確認訂單,確認完成后即完成了整個流程。
這兩種方案各有優(yōu)缺點。REST API方案會跳出你的頁面,支付完成再回來只能重新打開你的頁面。Javascript SDK方案下單是由前端完成的,服務(wù)端都不知道前端什么時候下單的,上來就被我否定了-_-。不過最終找到了一個結(jié)合REST API和 Javascript SDK 的第三種方案,既不用跳出頁面,也可以由服務(wù)端下單。PayPal示例地址:
下面就說明第三種方案的具體接入要點。
服務(wù)端請求 下單接口 。
請求Header中需要設(shè)置 Content-Type: application/json 和 Authorization,Authorization可以使用 Bearer Access-Token or Basic client_id:secret 兩種方式。使用Bearer Access-Token方式的話需要通過 授權(quán)接口 先獲得Access-Token。如果使用 Basic client_id:secret 方式的話直接 Basic Base64Encode(client_id:secret) 即可。
請求參數(shù)中需要設(shè)置幣種和金額,如果是單純的使用REST API方案的話,還需要再application_context中設(shè)置一個return_url。CURL示例如下:
下單完成后,會返回PayPal的訂單ID,和PayPal的支付鏈接(approve url)。將PayPal訂單ID返回給前端JS SDK,PayPal會自動打開一個頁面讓用戶付款,付款完SDK會通知你用戶付款完成。如果再PayPal后臺有配置付費事件(Checkout order approved)的webhook的話,PayPal服務(wù)器也會通過webhook通知你用戶已付款。
此時訂單處于APPROVED狀態(tài),需要你請求 Capture payment for order 接口去確認訂單。CURL示例如下:
如果確認完成,PayPal會響應(yīng)訂單狀態(tài)為COMPLETED,此狀態(tài)表示訂單已經(jīng)完成了。
打開開發(fā)者后臺,進入沙箱賬號列表: ,點擊Create account按鈕創(chuàng)建沙箱付款賬號,創(chuàng)建完成后點擊賬號列表后的View/edit account按鈕查看賬號郵箱和密碼。使用此賬號即可在沙箱環(huán)境中完成付款。
服務(wù)端請求 查詢訂單詳情接口 ,按文檔接入即可。
在開發(fā)者后臺,應(yīng)用列表頁面選擇Live選項卡,創(chuàng)建正式應(yīng)用,獲得正式clientID和Secret,替換沙箱密鑰,并將沙箱接口替換成功正式接口即可。
如果需要服務(wù)端接收事件,也需要給正式應(yīng)用配置對應(yīng)的webhook。
沙箱接口地址:
正式接口地址:
function rfq(){
var inputlist=document.getElementsByTagName("input"),
nameexpr=/qty\d*/,
valueexpr=/\d+/,
iserror=false,
i=0;
for(;iinputlist.length;i++){
if(nameexpr.exec(inputlist[i].name) !valueexpr.exec(inputlist[i].value)){
inputlist[i].style.backgroundColor="#FF0000";
iserror=true;
}else{
inputlist[i].style.backgroundColor="#FFFFFF";
}
}
if(iserror){
alert("紅色框處請輸入數(shù)字");
}
}
javascript簡稱JS,是網(wǎng)頁中使用的動態(tài)腳本程序,一般使用它的都是用于像彈出菜單、滑動切換、BANNER切換等特效。
一個頁面不易使用過多的JS,且JS要符合WEB標(biāo)準,并兼容常用瀏覽器,否則JS效果在某些瀏覽器中無法實現(xiàn),就會出現(xiàn)類似提示說JS代碼錯誤之類的,就算沒有錯誤提示也會不顯示此效果了。
很多網(wǎng)站的某些功能就用JS來觸發(fā),由于瀏覽器不兼容性問題而不執(zhí)行此功能。比如:以前的很多網(wǎng)站的支付功能、下單功能等。