在開發中,很多時候我們都會用到支付寶支付和微信支付,前段時間已經總結過微信支付流程,這里再說下支付寶支付(相對來說覺得支付寶有點坑),先說下支付寶支付的流程,如下圖:
一、支付流程理解
先看個圖
流程和咱們平時在手機上買東西是一樣的:
1.用戶選好商品后,點擊提交訂單(一般是這樣),選擇使用支付寶付款。
2.手機客戶端(你做的APP)把用戶選擇的商品的信息傳給你們后臺服務器。
3.后臺的服務器將各種數據拼接簽名后生成一個簽名后的字符串,回傳到客戶端APP上。
4.用戶點擊確認支付按鈕,調用手機支付寶客戶端,利用后臺傳過來的那個參數調起支付寶,讓支付寶客戶端傳給他們服務器交互,進行付款。(這一步是支付寶自己完成的,安全性高)
5.支付寶的服務器將支付的結果(可能成功也可能不成功)返回給手機支付寶客戶端和你們公司的后臺服務器。
6.你們公司后臺服務器收到后一般是更新下數據信息,手機支付寶客戶端會顯示一下支付成功。
二、支付流程詳解
下載支付寶SDK
App支付DEMO&SDK進入支付平臺注冊應用
創建應用獲取支付相關的 '私鑰' 和 '密鑰'
RSA私鑰及公鑰生成集成支付寶SDK
可以先看下官方集成文檔,下面是一些具體步驟:
4.1 導入文件(如下圖)
這里有一個注意點:如果不在客戶端上簽名,只需要發送訂單和處理支付返回結果,只需要添加AlipaySDK.bundle和AlipaySDK.framework就行了。
4.2 導入相關的依賴庫
4.3 為URL Types 添加支付寶回調scheme
identifier必須為 alipayShare
URL Schemes 命名規則:ap+AppID,需要和代碼中的一致
4.4 代碼部分
- 發送訂單的方法
- (void)payOrder:(NSString *)orderStr
fromScheme:(NSString *)schemeStr
callback:(CompletionBlock)completionBlock;
- 在AppDelegate中處理事件回調
在 APAppDelegate.m 文件中,增加引用代碼:
#import <AlipaySDK/AlipaySDK.h>
在@implementation AppDelegate中增加如下代碼:
#pragma mark - 處理返回結果
- (BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation
{
//如果極簡開發包不可用,會跳轉支付寶錢包進行支付,需要將支付寶錢包的支付結果回傳給開發包
if ([url.host isEqualToString:@"safepay"]) {
[[AlipaySDK defaultService] processOrderWithPaymentResult:url standbyCallback:^(NSDictionary *resultDic) {
//【由于在跳轉支付寶客戶端支付的過程中,商戶app在后臺很可能被系統kill了,所以pay接口的callback就會失效,請商戶對standbyCallback返回的回調結果進行處理,就是在這個方法里面處理跟callback一樣的邏輯】
NSLog(@"result = %@",resultDic);
}];
}
if ([url.host isEqualToString:@"platformapi"]){//支付寶錢包快登授權返回authCode
[[AlipaySDK defaultService] processAuthResult:url standbyCallback:^(NSDictionary *resultDic) {
//【由于在跳轉支付寶客戶端支付的過程中,商戶app在后臺很可能被系統kill了,所以pay接口的callback就會失效,請商戶對standbyCallback返回的回調結果進行處理,就是在這個方法里面處理跟callback一樣的邏輯】
NSLog(@"result = %@",resultDic);
}];
}
return YES;
}
- 集成到這里就差不多了,另外再推薦幾篇好文章:
- 這篇是客戶端做的時候遇到的坑:點這里。
- 如果簽名數據是在App上做的,可以參考下這篇文章,已經封裝好的,點這里。
- 這個是官方的集成流程,很詳細,點這里。
- iOS 集成支付寶
- 集成支付寶錢包支付iOS SDK的方法與經驗