IOS集成第三方支付、分享、登錄功能小結
作者 蠟筆小新
2016.7.1。由于蘋果強制要求適配ipv6,本文demo中采用的sdk可能有點老,如果采用的話,審核可能被拒。建議升級各SDK的新版本再集成,方法大同小異,有什么問題歡迎交流
集成ShareSDK社會化分享的時候集成了微信支付或者支付寶支付功能
(分別集成了微信支付和支付寶,用Ping++集成支付的煩請繞行…)
2016.01.07 更新(修改Xcode7.2 IOS9.2 微信客戶端操作之后返回程序 ?微信的onResp回調方法不被執行的bug)
http://yun.baidu.com/share/link?shareid=187711184&uk=3055516665
不廢話,先甩鏈接
第一,你需要有微信開發平臺的開發者賬號,(網址https://open.weixin.qq.com/,或者自行百度“微信open”,支付寶支付同理,下同),并將你要集成的應用在你的開發者賬號中注冊,并獲取支付權限(一般這步不需要程序員考慮,都是客戶自己獲取的,你只需要知道,沒有支付權限的應用,不可以集成支付)。
第二,注冊完你的應用,通過審核之后,你會獲得開放平臺給你發放屬于這個應用的AppID和AppSecret
第三,在開發平臺的資源中心(或者叫文檔中心,SDK中心什么的),下載IOS的SDK(文檔也可以下載下來方便查閱)。我這次的Demo是之前集成過ShareSDK的分享和第三方登錄,所以直接用的ShareSDK中的微信SDK。
(ps,這里之前網友有過用ShareSDK中的微信SDK不支持支付功能,我這里是可以支付的,應該是Mob集成好了,如果你下載的不能用的話,可以去微信官方下載官方的SDK,10M左右的樣子,把ShareSDK中的微信SDK替換掉,替換的時候要注意,不能只替換文件,要看好工程中Target選項卡里的文件路徑是否刪除了舊文件路徑,否則的話可能舊文件路徑會覆蓋新文件路徑,導致替換沒有效果或者崩潰。)
第四,將下載好的SDK拷貝到工程文件夾中,然后再工程中AddFilesTo“你的工程”,
(這里注意,Add的時候要勾選CopyItemsIfNeeed,否則可能會出現找不到路徑這種煩人的錯誤)
第五,配置你的工程。
1.添加系統依賴庫,(這里我用了ShareSDK,所以也連Share必須的系統庫也一并添加了),方法—點擊工程名—Target—BuildPhases—Link Binary With Libraries—點擊+號搜索你需要的系統庫,并添加
SystemConfiguration.framework
QuartzCore.framework
CoreTelephony.framework
libicucore.dylib(ps,這里因為可能你的Xcode是Xcode7,所以這里的.dylib可能會在你的系統庫里顯示.tbd)正常添加就好
libz.1.2.5.dylib
Security.framework
JavaScriptCore.framework
libstdc++.dylib
CoreText.framework
libsqlite3.dylib
ImageIO.framework (shareSDK新浪必須依賴庫)
AdSupport.framework(shareSDK新浪必須依賴庫)
2.配置工程的URL Types中的URL Schemes,
這個URL Schemes是用來調起第三方客戶端支付或分享或授權之后回到你的程序的標識
方法:點擊工程名—Target—Info—URL Types—點擊+號,在URL Schemes欄中填入你在第二步中獲取到的APPID(圖見上一步,自己找一下info選項卡)
3.如果是Xcode7需要在Info.Plist文件中加入字段LSApplicationQueriesSchemes,為Array類型,然后在里面添加兩個小選項,分別為weixin和wechat(Xcode7http請求適配Xcode7的問題請自行百度)
第六、開始寫代碼了!
1.將Demo中的WXPay文件夾拷貝到工程文件夾中,然后Add到工程目錄
2.在AppDelegate.h中#import相關頭文件,在AppDelegate.m文件中的application:(UIApplication
*)applicationdidFinishLaunchingWithOptions:(NSDictionary
*)launchOptions
方法中添加[WXApi registerApp:APP_ID
withDescription:@"demo
2.0"];(這里的APPID就是你第二步獲取的APPID,一般建議寫成宏。@“demo2.0”不需要修改),我的demo里在這個方法里還注冊了shareSDK,希望大家不要有疑惑。
3.在AppDelegate.m中加入這兩個方法:
//重要更新,一下兩個方法IOS9.0以后被廢棄了,所以如果你是Xcode7.2的話,可能會出現不能進入微信的onResp回調方法,原因是下邊兩個方法沒有被調用,所以這里更新一下,改用另外一個方法(并不建議刪除這兩個方法,新方法是9.0以后的方法,可能系統低版本的用戶不支持。所以我三種方法都留下了,如果有人發現不能都留下的話,請簡信告訴我一下,再次謝過了)
-(BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url;
-
(BOOL)application:(UIApplication *)application openURL:(NSURL *)url
sourceApplication:(NSString *)sourceApplication
annotation:(id)annotation;
//改用方法為- (BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary*)options;
具體方法里的代碼如何書寫請看Demo中的注釋。
4.配置完AppDelegate文件之后,向你的工程中拷貝入Demo中的UIViewController+WeChatAndAliPayMethod類目,并Add到工程中,
在你需要用到支付的頁面引用這個類目。(詳情請見Demo的ViewController頁面方法和代碼,仔細觀看注釋和理解代碼之后微信支付的集成就完成了)
PS.支付寶集成和微信支付集成大同小異,如果你集成了微信支付,你會發現支付寶集成更簡單。
第一步,將支付寶支付的SDK拷貝到工程文件夾中,然后Add到工程目錄,
(ps。這里注意一下,我demo里ThirdParty下的AliPay那些文件都是需要你在這一步拷貝的東西。)
尤其是openssl和Util還有那兩個.a文件。因為支付寶的開發文檔寫的實在是不怎么樣,亂七八糟的,都沒有直接給你要添加的SDK包,這些東西都是從官方的demo里抽出來的。具體你們可以下載官方demo看一看。
第二步、Add完SDK包之后,引入所需的系統庫。調用UIViewController+WeChatAndAliPayMethod這個類目中的支付寶支付方法即可。(注意看我Demo中的代碼和注釋)
PS。如果你在集成支付寶的時候可能會遇到not
found的錯誤,(你平時用別的SDK的時候也可能會遇到),這一般情況是Xcode找不到這些文件的路徑。在這里,你可以在Targets中的BuildSettings中的Header
Search Paths選項卡中添加openssl的路徑。
重點:Demo里有兩個存放關鍵幾個宏的文件,payRequsesrHandler.h和AliPayNeedDEF.h,這兩個文件里面的內容你們要自己填寫自己的數據。具體如何獲取這些數據我的注釋寫的很明白了。仔細看一下就好。
還有,你們在調用我的支付類目中的方法的同時,要寫一個監聽,來通知你是否支付成功。這個在我的代碼注釋里寫的很清楚,這里就不多贅述了。
接下來的部分是后來新增的。(三方登錄,和三方分享,包括適配ios9)
注:三方登錄和分享這些代碼Mob官網都有,就不多贅述了。這里主要是為了減少大家的代碼量,增強復用性進行的一些整合。如果哪里有問題或者處理不妥,希望碼友們積極提出。
首先,能做到三方登錄的話,和支付一樣,需要你在第三方平臺上注冊的應用擁有登錄權限。
其次,XCode7之后IOS9,shareSDK對應也有相應的變化,第三方分享登錄的時候,需要比之前多一些步驟,比如添加Schemes白名單:
info.plist中需要添加如此多的字段(為了適應新的sso授權。以下只是新浪微博,QQ,微信三個平臺需要添加的字段)
添加LSApplicationQueriesSchemes數組型字段中的元素
為方便大家按需添加,這里進行分類:
新浪微博:sinaweibo,
sinaweibohd,
sinaweibosso,
sinaweibohdsso,
weibosdk,(添加weibosdk需要)
weibosdk2.5(添加weibosdk需要)
微信:
wechat,
weixin
QQ:
mqqOpensdkSSoLogin,
mqqopensdkapiV2,
mqqopensdkapiV3,
wtloginmqq2,
mqq,
mqqapi
(以下是QQZone需添加的,但是一般情況一下,需要集成QQ分享登錄的,都需要QQZone的,所以一般建議大家直接把QQ和QQzone的都添加進去)
mqzone
mqzoneopensdk,
mqzoneopensdkapi,
mqzoneopensdkapi19,
mqzoneopensdkapiV2,
還有,不要忘記對URLType里面的設置。(QQ添加的時候需要用十六進制轉化的,例:QQ41D9BC03)
關于登錄的簡單整理:
我的demo工程中有個LoginMethodObject文件夾,里面有我自己新建的一個類LoginMethod。
使用者只需要引用這個類,實例化一個對象。并實現代理
-(void)recieveTheUserInfo:(NSDictionary*)userInfo
errorMsg:(NSString *)errorMsg;
userInfo即是獲取到的用戶信息。里面我只獲取了昵稱,uid,頭像等等簡單的信息。如果需要其他信息的話需要特別對待。不過一般登錄只需要uid就夠了,所以這里不過多贅述。
注意:在實現這個代理的時候,為了方便,邏輯更清楚。需要大家做下判斷,即判斷errorMsg是否存在。
(像AFNetWorking一樣)若存在errorMsg的話,說明獲取失敗,errorMsg打印出來即是錯誤原因。若errorMsg不存在代表獲取成功,就可以直接用userInfo中的用戶信息了
demo中的示例
具體可以看demo中的LoginViewController的運用。
關于第三方分享:
第三方分享的話,Mob的官網上寫的很明白了,我就不多此一舉再寫什么了。Demo中有樣板的,如果不想去mob翻的話,直接復制的話就可以了。
(單說一下,demo中寫的是適用于所有平臺均發送同一分享內容的方法。如果需要針對不同平臺分享不同內容的話需要調用另外一個方法,如下)