項目中用到了支付寶支付子寓,記錄一下集成過程
1、登錄支付寶開放平臺笋除,完成簽約斜友,完成簽約才可以創(chuàng)建應(yīng)用
2、創(chuàng)建應(yīng)用
我這個是app支付垃它,就選擇了支付應(yīng)用鲜屏,可以根據(jù)自己的需要,選擇相應(yīng)的類型国拇,名稱洛史,一般寫程序的名稱就行
申請完成,會有這個圖
注意狀態(tài)酱吝, 是在審核還是上線虹菲,上線就可以直接調(diào)用接口調(diào)試,如果是在審核中掉瞳,想要測試毕源,就用里邊的沙盒測試浪漠。
點擊圖中的查看
根據(jù)需要,簽約相應(yīng)功能霎褐,狀態(tài)顯示為已生效就可以使用了
下一步就是進(jìn)入應(yīng)用概述址愿,進(jìn)行環(huán)境配置了
支付寶網(wǎng)關(guān)不用設(shè)置,應(yīng)用網(wǎng)關(guān)就是支付寶驗證消息是不是你的商戶發(fā)出的請求冻璃,授權(quán)回調(diào)地址响谓,就是你支付的結(jié)果,支付寶會給這個地址發(fā)送一個post請求省艳,返回支付的結(jié)果等很多信息娘纷,后臺會給你一個地址,方便以后對賬等操作跋炕。
接下來就是加簽方式的設(shè)置了(這里赖晶,我是放在我這里處理,更好的方式是放在服務(wù)器生成辐烂,你直接用后臺給你公鑰上傳就行)遏插,我是用的支付寶給的密鑰生成工具,下載運行纠修,會是這樣的
根據(jù)你們后臺使用的開發(fā)語言胳嘲,進(jìn)行相應(yīng)的選擇,運行之后扣草,會得到一個應(yīng)用公鑰了牛,一個應(yīng)用私鑰
點擊設(shè)置應(yīng)用公鑰,上傳你生成的公鑰辰妙,成功之后白魂,會有一個支付寶公鑰,這個是支付寶直接生成的上岗,不用管
然后,驗證公鑰蕴坪,我是下載的支付寶提供的工具進(jìn)行驗證肴掷,打開驗證工具,是這樣的
如果你生成簽名的時候背传,選擇的是java適用呆瞻,那就可以直接把私鑰放進(jìn)去,點擊生成簽名径玖,如果不是痴脾,你可以打開你生成簽名的那個工具,有一個格式轉(zhuǎn)換
然后進(jìn)行上一步的驗證梳星,將生成的sign直接放入支付寶開放平臺的那個驗證框里就可以驗證了赞赖。
再驗證一下你的公鑰私鑰是不是匹配的滚朵,打開簽名生成工具
導(dǎo)入公鑰私鑰,如果匹配成功前域,那就說明辕近,簽名是正確的配置
接下來就是按照開發(fā)文檔導(dǎo)入SDK(沒找到pod方式安裝,只能手動導(dǎo)入了)匿垄,具體的可以看這個
其實對于我們客戶端來說移宅,很簡單,只需要調(diào)用這一個接口就行
AlipaySDK.defaultService().payOrder(sign, fromScheme: "ZhiFuBao") { (result) in
print("支付寶支付結(jié)果\(String(describing: result))")
}
前提是椿疗,后臺已經(jīng)幫我們把sign生成了漏峰,如果后臺不幫我們生成,那就需要我們自己生成届榄,可以看支付寶的demo
//重要說明
//這里只是為了方便直接向商戶展示支付寶的整個支付流程浅乔;所以Demo中加簽過程直接放在客戶端完成;
//真實App里痒蓬,privateKey等數(shù)據(jù)嚴(yán)禁放在客戶端童擎,加簽過程務(wù)必要放在服務(wù)端完成;
//防止商戶私密數(shù)據(jù)泄露攻晒,造成不必要的資金損失顾复,及面臨各種安全風(fēng)險;
/*============================================================================*/
/*=======================需要填寫商戶app申請的===================================*/
/*============================================================================*/
NSString *appID = @"";
// 如下私鑰鲁捏,rsa2PrivateKey 或者 rsaPrivateKey 只需要填入一個
// 如果商戶兩個都設(shè)置了芯砸,優(yōu)先使用 rsa2PrivateKey
// rsa2PrivateKey 可以保證商戶交易在更加安全的環(huán)境下進(jìn)行,建議使用 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設(shè)置
order.app_id = appID;
// NOTE: 支付接口名稱
order.method = @"alipay.trade.app.pay";
// NOTE: 參數(shù)編碼格式
order.charset = @"utf-8";
// NOTE: 當(dāng)前時間點
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 根據(jù)商戶設(shè)置的私鑰來決定
order.sign_type = (rsa2PrivateKey.length > 1)?@"RSA2":@"RSA";
// NOTE: 商品數(shù)據(jù)
order.biz_content = [BizContent new];
order.biz_content.body = @"我是測試數(shù)據(jù)";
order.biz_content.subject = @"1";
order.biz_content.out_trade_no = [self generateTradeNO]; //訂單ID(由商家自行制定)
order.biz_content.timeout_express = @"30m"; //超時時間設(shè)置
order.biz_content.total_amount = [NSString stringWithFormat:@"%.2f", 0.01]; //商品價格
//將商品信息拼接成字符串
NSString *orderInfo = [order orderInfoEncoded:NO];
NSString *orderInfoEncoded = [order orderInfoEncoded:YES];
NSLog(@"orderSpec = %@",orderInfo);
// NOTE: 獲取私鑰并將商戶信息簽名动羽,外部商戶的加簽過程請務(wù)必放在服務(wù)端包帚,防止公私鑰數(shù)據(jù)泄露;
// 需要遵循RSA簽名規(guī)范运吓,并將簽名字符串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: 如果加簽成功渴邦,則繼續(xù)執(zhí)行支付
if (signedString != nil) {
//應(yīng)用注冊scheme,在AliSDKDemo-Info.plist定義URL types
NSString *appScheme = @"alisdkdemo";
// NOTE: 將簽名成功字符串格式化為訂單字符串,請嚴(yán)格按照該格式
NSString *orderString = [NSString stringWithFormat:@"%@&sign=%@",
orderInfoEncoded, signedString];
// NOTE: 調(diào)用支付結(jié)果開始支付
[[AlipaySDK defaultService] payOrder:orderString fromScheme:appScheme callback:^(NSDictionary *resultDic) {
NSLog(@"reslut = %@",resultDic);
}];
}
這里,私鑰是我們自己保存的拘哨,如果后臺簽名谋梭,在“獲取私鑰并將商戶信息簽名”這一步,要使用自己生成的私鑰給后臺倦青,如果后臺嚴(yán)格按照開發(fā)文檔執(zhí)行簽名瓮床,這里就可以測試了,如果有錯誤,在調(diào)起支付寶的界面隘庄,會有錯誤代碼踢步,根據(jù)錯誤代碼,來修改相應(yīng)內(nèi)容峭沦,
支付結(jié)果的回調(diào)就在這個里邊
AlipaySDK.defaultService().payOrder(sign, fromScheme: "ZhiFuBao") { (result) in
//支付結(jié)果回調(diào)
}
根據(jù)不同結(jié)果贾虽,進(jìn)行不同處理,至此吼鱼,就可以完整的集成支付寶支付蓬豁。