項目中用到了支付寶支付,記錄一下集成過程
1、登錄支付寶開放平臺,完成簽約,完成簽約才可以創建應用
2、創建應用
我這個是app支付,就選擇了支付應用,可以根據自己的需要,選擇相應的類型,名稱,一般寫程序的名稱就行
申請完成,會有這個圖
注意狀態, 是在審核還是上線,上線就可以直接調用接口調試,如果是在審核中,想要測試,就用里邊的沙盒測試。
點擊圖中的查看
根據需要,簽約相應功能,狀態顯示為已生效就可以使用了
下一步就是進入應用概述,進行環境配置了
支付寶網關不用設置,應用網關就是支付寶驗證消息是不是你的商戶發出的請求,授權回調地址,就是你支付的結果,支付寶會給這個地址發送一個post請求,返回支付的結果等很多信息,后臺會給你一個地址,方便以后對賬等操作。
接下來就是加簽方式的設置了(這里,我是放在我這里處理,更好的方式是放在服務器生成,你直接用后臺給你公鑰上傳就行),我是用的支付寶給的密鑰生成工具,下載運行,會是這樣的
根據你們后臺使用的開發語言,進行相應的選擇,運行之后,會得到一個應用公鑰,一個應用私鑰
點擊設置應用公鑰,上傳你生成的公鑰,成功之后,會有一個支付寶公鑰,這個是支付寶直接生成的,不用管
然后,驗證公鑰,我是下載的支付寶提供的工具進行驗證,打開驗證工具,是這樣的
如果你生成簽名的時候,選擇的是java適用,那就可以直接把私鑰放進去,點擊生成簽名,如果不是,你可以打開你生成簽名的那個工具,有一個格式轉換
然后進行上一步的驗證,將生成的sign直接放入支付寶開放平臺的那個驗證框里就可以驗證了。
再驗證一下你的公鑰私鑰是不是匹配的,打開簽名生成工具
導入公鑰私鑰,如果匹配成功,那就說明,簽名是正確的配置
接下來就是按照開發文檔導入SDK(沒找到pod方式安裝,只能手動導入了),具體的可以看這個
其實對于我們客戶端來說,很簡單,只需要調用這一個接口就行
AlipaySDK.defaultService().payOrder(sign, fromScheme: "ZhiFuBao") { (result) in
print("支付寶支付結果\(String(describing: result))")
}
前提是,后臺已經幫我們把sign生成了,如果后臺不幫我們生成,那就需要我們自己生成,可以看支付寶的demo
//重要說明
//這里只是為了方便直接向商戶展示支付寶的整個支付流程;所以Demo中加簽過程直接放在客戶端完成;
//真實App里,privateKey等數據嚴禁放在客戶端,加簽過程務必要放在服務端完成;
//防止商戶私密數據泄露,造成不必要的資金損失,及面臨各種安全風險;
/*============================================================================*/
/*=======================需要填寫商戶app申請的===================================*/
/*============================================================================*/
NSString *appID = @"";
// 如下私鑰,rsa2PrivateKey 或者 rsaPrivateKey 只需要填入一個
// 如果商戶兩個都設置了,優先使用 rsa2PrivateKey
// rsa2PrivateKey 可以保證商戶交易在更加安全的環境下進行,建議使用 rsa2PrivateKey
// 獲取 rsa2PrivateKey,建議使用支付寶提供的公私鑰生成工具生成,
// 工具地址:https://doc.open.alipay.com/docs/doc.htm?treeId=291&articleId=106097&docType=1
NSString *rsa2PrivateKey = @"";
NSString *rsaPrivateKey = @"";
/*============================================================================*/
/*============================================================================*/
/*============================================================================*/
//partner和seller獲取失敗,提示
if ([appID length] == 0 ||
([rsa2PrivateKey length] == 0 && [rsaPrivateKey length] == 0))
{
UIAlertView *alert = [[UIAlertView alloc] initWithTitle:@"提示"
message:@"缺少appId或者私鑰。"
delegate:self
cancelButtonTitle:@"確定"
otherButtonTitles:nil];
[alert show];
return;
}
/*
*生成訂單信息及簽名
*/
//將商品信息賦予AlixPayOrder的成員變量
Order* order = [Order new];
// NOTE: app_id設置
order.app_id = appID;
// NOTE: 支付接口名稱
order.method = @"alipay.trade.app.pay";
// NOTE: 參數編碼格式
order.charset = @"utf-8";
// NOTE: 當前時間點
NSDateFormatter* formatter = [NSDateFormatter new];
[formatter setDateFormat:@"yyyy-MM-dd HH:mm:ss"];
order.timestamp = [formatter stringFromDate:[NSDate date]];
// NOTE: 支付版本
order.version = @"1.0";
// NOTE: sign_type 根據商戶設置的私鑰來決定
order.sign_type = (rsa2PrivateKey.length > 1)?@"RSA2":@"RSA";
// NOTE: 商品數據
order.biz_content = [BizContent new];
order.biz_content.body = @"我是測試數據";
order.biz_content.subject = @"1";
order.biz_content.out_trade_no = [self generateTradeNO]; //訂單ID(由商家自行制定)
order.biz_content.timeout_express = @"30m"; //超時時間設置
order.biz_content.total_amount = [NSString stringWithFormat:@"%.2f", 0.01]; //商品價格
//將商品信息拼接成字符串
NSString *orderInfo = [order orderInfoEncoded:NO];
NSString *orderInfoEncoded = [order orderInfoEncoded:YES];
NSLog(@"orderSpec = %@",orderInfo);
// NOTE: 獲取私鑰并將商戶信息簽名,外部商戶的加簽過程請務必放在服務端,防止公私鑰數據泄露;
// 需要遵循RSA簽名規范,并將簽名字符串base64編碼和UrlEncode
NSString *signedString = nil;
RSADataSigner* signer = [[RSADataSigner alloc] initWithPrivateKey:((rsa2PrivateKey.length > 1)?rsa2PrivateKey:rsaPrivateKey)];
if ((rsa2PrivateKey.length > 1)) {
signedString = [signer signString:orderInfo withRSA2:YES];
} else {
signedString = [signer signString:orderInfo withRSA2:NO];
}
// NOTE: 如果加簽成功,則繼續執行支付
if (signedString != nil) {
//應用注冊scheme,在AliSDKDemo-Info.plist定義URL types
NSString *appScheme = @"alisdkdemo";
// NOTE: 將簽名成功字符串格式化為訂單字符串,請嚴格按照該格式
NSString *orderString = [NSString stringWithFormat:@"%@&sign=%@",
orderInfoEncoded, signedString];
// NOTE: 調用支付結果開始支付
[[AlipaySDK defaultService] payOrder:orderString fromScheme:appScheme callback:^(NSDictionary *resultDic) {
NSLog(@"reslut = %@",resultDic);
}];
}
這里,私鑰是我們自己保存的,如果后臺簽名,在“獲取私鑰并將商戶信息簽名”這一步,要使用自己生成的私鑰給后臺,如果后臺嚴格按照開發文檔執行簽名,這里就可以測試了,如果有錯誤,在調起支付寶的界面,會有錯誤代碼,根據錯誤代碼,來修改相應內容,
支付結果的回調就在這個里邊
AlipaySDK.defaultService().payOrder(sign, fromScheme: "ZhiFuBao") { (result) in
//支付結果回調
}
根據不同結果,進行不同處理,至此,就可以完整的集成支付寶支付。