一 API版本說明
下面是官網的說明:
做個簡單說明: API1.0接口主要用于網站(包括手機端的網站)的調用;API2.0主要用于手機app的調用。根據我們做的手機端網站的接口開發,主要使用API1.0接口。
API1.0接口的請求參數如下:
根據上面的請求參數做開發前的準備工作。
二 開發準備工作
2.1 首先需要注冊支付寶企業賬戶
詳細步驟參考支付寶企業版官網注冊。
2.2 PID(partner_id的簡稱),合作伙伴身份
由于我沒有注冊企業賬戶,就用一下官網的截圖
2.3 密鑰(簽名)
由于支付寶接口的開發涉及到RMB,所以在請求前后,都要加密,合作伙伴身份的密匙主要有三種方式簽名(MD5、RSA、DSA),api1.0版本只支持MD5、RSA。但由于無線快捷支付只支持RSA,所以手機網站支付簽名只能采用RSA。
RSA簽名由公匙和私匙組成,公匙是開放的,私匙一定要保存好。
2.3.1商戶(開發者)的RSA簽名生成
https://doc.open.alipay.com/doc2/detail.htm?spm=0.0.0.0.gf8Q4m&treeId=115&articleId=103242&docType=1)詳細參考生成簽名的網站。
(1)下載并安裝OpenSSL工具
(2)java開發時注意事項
2.4上傳商戶(開發者)密匙
開發的產品要和支付寶交互,吧商戶自己的公匙上傳到支付寶平臺,使支付寶平臺對請求的訂單解密。和上傳本地的公匙到github上面的原理一樣,參考下面的網站
https://doc.open.alipay.com/doc2/detail.htm?spm=0.0.0.0.95uDlm&treeId=58&articleId=103578&docType=1
三 手機網站支付交互流程
3.1 手機網站支付流程
(1)商戶(開發者產品)根據上文提到的請求參數構造數據集合
(2)把構造完成的數據集合,通過頁面鏈接跳轉的方式傳遞給支付寶。注意這里在發送之前用到我們前面提到RSA,用商戶自己的私匙去加密。
(3)支付寶平臺首先對得到的數據集合,用商戶上傳的公匙去解密,看有沒有人攔截。然后進行數據處理,吧處理完成的數據用支付寶的私匙去加密。
(4)返回處理的結果數據。(官網給了兩種方法,如下圖)
(5)對獲取的返回結果數據進行處理
3.2 退款流程(后續研究)
對通過即時到賬等接口付款完成的交易進行部分或全部的退還。商戶(開發者賬號)需輸入支付密碼。
即時到賬有密退款網址如下:
https://doc.open.alipay.com/doc2/detail.htm?spm=0.0.0.0.99u19c&treeId=66&articleId=103571&docType=1
Demo下載地址:
https://doc.open.alipay.com/doc2/detail?treeId=54&articleId=103419&docType=1
四 手機網站支付官網Demo
4.1 Demo下載及簡單說明
我們對照支付寶提供的手機網站支付Demo,來做個簡單說明
(1)手機網站支付下載頁面:
https://doc.open.alipay.com/doc2/detail?treeId=54&articleId=103419&docType=1
(2)demo提供了三個版本php、java、c#、asp,我么選用java版本
4.2 代碼分析
4.2.1 請求參數(和我們前面提到的一樣)
4.2.2 簽名文件
果然是RSA簽名
4.2.3 主要功能
下面可證明手機網址支付使用的是API1.0版本