前言
針對(duì)iOS的支付,在之前,TTFrameWork僅僅寫(xiě)了關(guān)于蘋(píng)果的內(nèi)購(gòu)AppPurchaseManager,這次的更新,我融入了關(guān)于第三方(支付寶和微信)支付,采用最簡(jiǎn)單的調(diào)用方式,一站式解決方案.
提醒
根據(jù)微信支付和阿里(支付寶)支付的官方SDK的說(shuō)明,進(jìn)行支付的簽名等一些信息,盡量放到 服務(wù)端 去做,特別是阿里支付需要涉及到 私鑰(yuè) ,這里,為了方便開(kāi)發(fā)者更容易理解,將簽名的過(guò)程和內(nèi)容放到客戶(hù)端進(jìn)行處理.
用途
針對(duì)蘋(píng)果的審核理念,虛擬貨幣必須使用蘋(píng)果內(nèi)購(gòu),比如會(huì)員的充值等等,但是,限制于蘋(píng)果服務(wù)器的不穩(wěn)地以及高延遲,很多國(guó)內(nèi)的開(kāi)發(fā)者就按耐不住躁動(dòng)的心,開(kāi)始網(wǎng)項(xiàng)目中融入國(guó)內(nèi)的微信和阿里支付,當(dāng)然,這個(gè)也是需要技巧的,不如審核隱藏什么的,這個(gè)具體的方案就不多說(shuō)了,畢竟存在風(fēng)險(xiǎn),而且已經(jīng)舉報(bào),查實(shí)就會(huì)被下架,特別是知名的APP,比如QQ購(gòu)買(mǎi)會(huì)員依然是內(nèi)購(gòu),所以,這個(gè)就看你們是怎么選擇了.
正傳
下面針對(duì)更新進(jìn)行說(shuō)明:
1. 導(dǎo)入庫(kù),關(guān)于相關(guān)的庫(kù)的導(dǎo)入,請(qǐng)參考微信和支付寶sdk,那里比較詳細(xì)
ps:導(dǎo)入庫(kù)會(huì)出現(xiàn)很多問(wèn)題,后續(xù),我會(huì)在我的簡(jiǎn)書(shū),推出相關(guān)的解決方案
2. 設(shè)置相關(guān)的注冊(cè)的信息:
在TTConst中進(jìn)行設(shè)置
// 微信
#define WECHATAPPIDKEY @"" // appiid
#define WECHATAPPSECRETKEY @"" // SECRETKEY
#define WECHATPARTNERID @"" // 商戶(hù)號(hào)
#define WECHATPARTNERKEY @"" // 密鑰
// 阿里
#define ALIPAYAPPID @"" // appid
#define ALIPAYPRIVATEKEY @"" // 私鑰(這個(gè)對(duì)于阿里支付的私鑰,建議放到服務(wù)器端去做)
3. UIAppleDelegate中的設(shè)置
-
注冊(cè)微信和阿里支付的相關(guān)SDK
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions { return [TTPAY_MANAGER registerApp];
}
* #####微信/支付寶APP對(duì)支付結(jié)果進(jìn)行回調(diào)
這里需要執(zhí)行協(xié)議,也就是微信和支付寶在客戶(hù)端支付完后,會(huì)進(jìn)行APP進(jìn)行跳轉(zhuǎn)的回調(diào),相關(guān)的信息會(huì)通過(guò)協(xié)議進(jìn)行表達(dá).
>這里,我們對(duì)兩種支付方式的回調(diào)進(jìn)行了分裝,通過(guò)Url.host進(jìn)行區(qū)分,這里具體如實(shí)現(xiàn)可以查看實(shí)現(xiàn)方式.
iOS 9.0 之前
- (BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation {
return [TTPAY_MANAGER handleUrl:url];
}
iOS 9.0 之后
- (BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary<NSString*, id> *)options {
return [TTPAY_MANAGER handleUrl:url];
}
##### 4. 使用
* #####相關(guān)Model進(jìn)行賦值
創(chuàng)建微信和支付寶對(duì)應(yīng)的數(shù)據(jù)Model
![阿里支付Model](http://upload-images.jianshu.io/upload_images/2363764-427207acc5f0df14.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
![微信支付Model](http://upload-images.jianshu.io/upload_images/2363764-579f16ed0964492b.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
記住, **數(shù)據(jù)均不為空** ,因?yàn)檫@里的數(shù)據(jù)是獲取的支付的關(guān)鍵參數(shù),如果需要設(shè)置其他的參數(shù),可以參考上面的SDK內(nèi)容.如果為空,可能導(dǎo)致不跳轉(zhuǎn)或者支付失敗.
如果考慮服務(wù)器返回?cái)?shù)據(jù)為空的情況,可以在model的屬性的get方法中,進(jìn)行重寫(xiě),防止為空的情況,因?yàn)闉榭盏脑?會(huì)導(dǎo)致不跳轉(zhuǎn)等等意外情況
* #####舉例使用
下面拿阿里(支付寶)支付進(jìn)行說(shuō)明:
1. 創(chuàng)建Model,進(jìn)行賦值:
AliPayModel *model = [AliPayModel new];
model.notifyUrl = item.aliPayNotifyUrl; // 這里的回調(diào)地址是服務(wù)器給的
model.price = self.orderItem.originalPrice;
model.orderNo = item.orderCode; // 這里是服務(wù)器定義的商品的標(biāo)識(shí)碼
model.payTitle = @"title";
model.body = @"description";
2. 調(diào)用payWithOrderMessage,傳入model就行,接下來(lái)會(huì)有相關(guān)的狀態(tài)進(jìn)行回調(diào)
[TTPAY_MANAGER payWithOrderMessage:model successBlock:^{
NSLog(@"----成功了");
} cancelBlock:^{
NSLog(@"----取消了");
} failureBlock:^(NSString *errStr) {
NSLog(@"----失敗了");
}];
最后,可以通過(guò)回調(diào)進(jìn)行相應(yīng)的處理,從而完成支付.
##補(bǔ)充:
整套的支付開(kāi)發(fā)流程,大家可以去查看一下對(duì)應(yīng)的SDK,需要補(bǔ)充的是,畢竟這個(gè)不是自家的東西,很多東西局限性在于延遲或者數(shù)據(jù)對(duì)接問(wèn)題,因此,你需要跟服務(wù)器對(duì)接好,比如服務(wù)器驗(yàn)證回調(diào)信息等等情況,以及相關(guān)的已經(jīng)扣款,但是服務(wù)器無(wú)響應(yīng)的情況,這個(gè)需要根據(jù)具體的產(chǎn)品需求進(jìn)行相關(guān)的設(shè)置.
##總結(jié):
在開(kāi)始的時(shí)候,看SDK的說(shuō)明文檔很懵逼,因?yàn)?參數(shù)太多,看不過(guò)來(lái),而且也不知道哪些是需要填寫(xiě)的,哪些是選擇填寫(xiě)的,而且,涉及到公司產(chǎn)品的需求,許多東西需要?jiǎng)討B(tài)化處理.當(dāng)時(shí)查看了很多的Demo,發(fā)現(xiàn)都是采用的官網(wǎng)給給出的Demo實(shí)例,針對(duì)簽名部分,并沒(méi)有給出很清楚的實(shí)例,如微信的二次簽名,以及支付寶的私鑰簽名,這個(gè)其實(shí)是接入支付SDK的難點(diǎn),因?yàn)?決定雷鋒一把,寫(xiě)了這個(gè)傻瓜式的支付Tool,這個(gè)你可以直接拿過(guò)去用,拖入自己的工程,會(huì)報(bào)一些錯(cuò)誤,可以從網(wǎng)上查找一下答案,這個(gè)網(wǎng)上都會(huì)有相關(guān)的內(nèi)容,我就不一一列舉了.
## 項(xiàng)目
這個(gè)第三方支付的Manager是我的TTFrameWork的一個(gè)分支,作為一個(gè)模塊,已經(jīng)上傳到Github了,歡迎大家多多下載.
總項(xiàng)目地址:[TTFrameWork](https://github.com/zhangfurun/TT)
支付項(xiàng)目地址:[TTOtherPayManager](https://github.com/zhangfurun/TT/tree/master/TTFrameWork/TTOtherPayManager)
TTFrameWork的簡(jiǎn)書(shū)地址:[TTFrameWork簡(jiǎn)書(shū)](http://www.reibang.com/p/0bd0ec075409)
###如果感覺(jué)有用的話,希望Github給個(gè)星星,謝謝