中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

iOS開發之App間賬號共享與SDK封裝

發布時間:2020-07-27 10:52:40 來源:網絡 閱讀:391 作者:zsdnr 欄目:移動開發

一、功能總述

在博客開始的第一部分,我們先來看一下我們最終要實現的效果。下圖中所表述的就是我們今天博客中要做的事情,下方的App One和App Two都植入了我們將要封裝的LoginSDK, 兩個App中都設置了Keychain Share。當App One通過我們的LoginSDK登錄后,在啟動App Two時,會去檢索是否有賬號以及在分享的Keychain中存儲了,如果有的話,那么不會彈出“登錄”界面,直接進行隱式登錄。當然上述這些工作都是在我們的LoginSDK中進行做的事情。

iOS開發之App間賬號共享與SDK封裝

本部分算是本篇博客的一個綜述吧,從下方截圖中,我們能清楚的看到上述的兩個App中都植入了我們接下來要封裝的SDK。LoginSDK.framework就是我們封裝的登錄靜態庫,其中提供了用戶所調用的API。

  iOS開發之App間賬號共享與SDK封裝

下方這個截圖中的內容就是用戶所調用LoginSDK的API。因為我們做的只是一個Demo,所以下方的API接口比較簡單,如果你要和現實App中真正的需求和業務邏輯整合到一塊,那么封裝一個登錄用的SDK是非常麻煩的。因為我考慮過把我們團隊所開發的幾個App中的登錄模塊封裝成SDK, 仔細考慮了一下,東西還是蠻多的。扯遠了,不過今天這個Demo還是可以提供一個大體思路的。

下方API的對象是通過單例來獲取的,如果是首次登錄的話,就需要調用getLoginViewController這個方法來獲取登錄頁面,并且這個函數需要提供一個Block參數,這個Block參數用來處理登錄成功后的事件。而登錄失敗等事件就在我們SDK中自行處理了。

checkHaveLogin方法是用來檢查是否已經有賬號登錄過,該方法需要提供兩個Block,一個是登錄成功要執行的Block,一個是沒有已登錄賬號時執行的Block。當執行該方法時,如果之前有賬號登錄過的話,就直接進行隱式登錄,登錄成功后執行loginSuccessBlock。之前如果沒有賬號在此設備上登錄就執行noAccountBlock, 來處理首次登錄的事件。

  iOS開發之App間賬號共享與SDK封裝

該部分先聊這么多,接下來會根據上述的知識點詳細的展開。

 

二、LoginSDK的封裝

在封裝LoginSDK之前呢,SDK的源代碼以及所依賴的資源得準備好對吧。下方截圖就是我們LoginSDK的源代碼,下方綠框中的部分是留給用戶使用的API, 而黃框中的部分就是我們這個SDK所依賴的資源了,雖然此處只用一個Storyboard,我們還是有必要將該資源文件打包成Bundle文件提供給用戶的。而其他源代碼SDK的用戶是看不到的。源碼準備好,測試完畢后,接下來我們就要進行SDK的封裝了。

  iOS開發之App間賬號共享與SDK封裝

 

1.創建iOS Framework工程

首先我們需要創建一個iOS的CocoaTouch工程,點擊Next,輸入我們Framework的名字即可。下方我們暫且將該Framework的名字命名為“CreateLoginSDKFramework”。如下所示:

  iOS開發之App間賬號共享與SDK封裝  iOS開發之App間賬號共享與SDK封裝

 

2.設定兼容版本

創建完工程后,我們要選擇“Deployment Target”, 此處我們選擇的是8.0。也就是說此處我們封裝的SDK所支持的iOS系統版本是iOS8.0+。

  iOS開發之App間賬號共享與SDK封裝

 

3.選擇“靜態庫”

我們創建的framework默認是動態庫,所以我們要講Mach-O Type設置為靜態庫“Static Library”,如下所示。

  iOS開發之App間賬號共享與SDK封裝

 

4.引入源代碼并進行編譯

配置好上述選項后,接下來我們就需要將我們事先準備好的SDK源代碼引入到我們的Framework的工程中進行編譯了,在編譯之前我們要選擇SDK用戶可以看到的文件。下方截圖中就是在Build Phases下的Headers中進行設置的。將用戶可以看到的頭文件房子Public中,用戶看不到的放在Project中。如下所示。

  iOS開發之App間賬號共享與SDK封裝

 

5.編譯

上述設置和配置完畢后,我們就要對我們的Framework工程進行編譯了。先選擇模擬器進行編譯,然后選擇真機進行編譯。編譯完后,在Products下會生成相應的Framework, 然后通過Show in Finder進行查看即可。查看時,如果想看“模擬器”和“真機”的framework的話,在Show in finder后,需要前往上層文件夾查看。具體如下所示。

  iOS開發之App間賬號共享與SDK封裝

 

6.Framework的合并

因為在模擬器下編譯會生成模擬器下使用的Framework,在真機下編譯會生成真機使用的Framework。如果想我們生成的Framework既可以在真機下使用,也可以在模擬器下使用,那么我們需要將兩個Framework進行合并。

下方截圖中,這兩個framework一個是真機生成的,另一個是模擬器生成的,我們做的事情就是將下方綠框中的兩個文件進行合并。然后使用合并后的文件將下方的文件替換即可。替換后的framework就可以在模擬器和真機下進行使用了。

  iOS開發之App間賬號共享與SDK封裝

我們使用“lipo -create 模擬器framework路徑  真機framework路徑 -output 新的文件”命令將上述兩個文件進行合并。下方就是合并上述兩個文件的執行命令, 執行完下方命令后會生成合并后的文件,將上述文件進行替換即可。經過上述步驟,我們的Framework至此就封裝完畢了。

  iOS開發之App間賬號共享與SDK封裝

 

三、封裝Bundle

封裝完Framework后,接下來我們要對Framework依賴的資源文件進行打包了。因為我們SDK中的界面是使用Storyboard做的,所以需要將Storyboard打包成Bundle資源文件與上述的Framework一起使用。如果我們SDK中需要一些圖片資源的話,也可以進行一并打包。接下來我們就要對資源文件進行打包。

1.Bundle工程的創建

首先我們像創建Framework工程一樣創建一個Bundle工程,因為iOS工程下方沒有Bundle類型的工程,所以我們需要在OS X -> Framework & Library -> Bundle下面來創建我們的Bundle工程。選擇完后,輸出我們的Bundle文件的名稱即可,如下所示:

  iOS開發之App間賬號共享與SDK封裝  iOS開發之App間賬號共享與SDK封裝

 

2. Bundle工程的配置

創建完Bundle工程后,我們要對其進行相應的配置。因為我們是選擇OS X創建的Bundle,默認的Bundle是不能在iOS中使用的,所以我們得將Base SDK進行設置,選擇相應的iOS版本即可,如下所示。選擇完Base SDK后,我們還要像上面Framework的封裝一樣,設置一下要兼容的iOS版本(iOS Deployment Target), 在此就不做過多贅述了。

  iOS開發之App間賬號共享與SDK封裝

 

3.引入資源,進行編譯

進行上述配置完后,接下來就是引入資源文件進行編譯了,下方引入的資源文件就是我們的LoginSDK.storyboard。引入資源后,進行編譯,編譯后會在Products下面生成相應的Bundle資源文件,該文件就可以和我們的Framework進行使用了。

  iOS開發之App間賬號共享與SDK封裝

 

4.Bundle資源的加載

生成完Bundle資源文件后,我們在SDK的源代碼中,要從Bundle資源文件中進行資源的加載。下方代碼就是加載相應Bundle的代碼。通過下方的宏定義,就可以通過“Bundle”的名字來加載Bundle。下方的LOGIN_SDK_BUNDLE就是我們要使用的Bundle資源文件的對象。

#define LOGIN_SDK_BUNDLE_NAME   @"LoginSDKResource.bundle"#define LOGIN_SDK_BUNDLE_PATH   [[[NSBundle mainBundle] resourcePath] stringByAppendingPathComponent: LOGIN_SDK_BUNDLE_NAME]#define LOGIN_SDK_BUNDLE        [NSBundle bundleWithPath: LOGIN_SDK_BUNDLE_PATH]

下方代碼就是從上述Bundle對象中加載相應的Storyboard。與我們之前的代碼不同,之前我們是從MainBundle中加載的Storyboard,而現在我們是從指定的Bundle中來加載Storyboard。具體代碼如下所示。

  iOS開發之App間賬號共享與SDK封裝

 

四、SDK的引入

SDK已經依賴的資源文件封裝完畢后,接下來就是在其他App中使用了。在第一部分中的App One和App Two都引入了上述我們封裝的LoginSDK。引入SDK步驟也是比較簡單的,這和引入友盟,個推,微信支付,支付寶等等SDK的步驟差不多。下方就是我們引入SDK的步驟。

1.導入SDK并進行相關配置

導入SDK到我們的App工程后,我們要對其進行相應的配置。首先我們要對Framework Search Paths進行配置,也就是說告訴編譯器我們的第三方SDK所在的位置。下方這個配置項在引入SDK后就默認存在的,如果沒有的話就進行配置即可。

  iOS開發之App間賬號共享與SDK封裝

 

配置完路徑后,接下來我們要在Other Linker Flags添加上-Objc和-all_load選項。這兩個選項在之前的博客中也不止一次的提到過。-Objc這個flag告訴鏈接器把庫中定義的Objective-C類和Category都加載進來。而-all_load會強制鏈接器把目標文件都加載進來,即使沒有objc代碼。根據上面介紹的,下方即使不添加-Objc這個選項,下方的工程也是可以正常運行的。

  iOS開發之App間賬號共享與SDK封裝

 

2.SDK的使用

配置完畢后,接下來就是在我們App中使用該SDK了。下方代碼就是我們上述LoginSDK的使用方式,首先獲取單例,然后檢查是否登錄,登錄成功后根據Block回調跳轉到首頁,如果未登錄,就通過LoginAPI獲取登錄頁面進行登錄。具體如下所示。

  iOS開發之App間賬號共享與SDK封裝

 

五、Keychain共享

關于Keychain共享的東西,我們可以看一下上一篇博客的介紹《iOS逆向工程之KeyChain與Snoop-it》。而在本篇博客中,是對keychain共享的應用,在植入上述LoginSDK后,如果想多個App間進行賬號共享的話,要在相應的App上添加Keychain Share的標示了。下方截圖就是我們第一部分那兩個App中所設置的Keychain共享的配置項了。具體如下所示。

  iOS開發之App間賬號共享與SDK封裝


向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

晴隆县| 策勒县| 延长县| 金溪县| 得荣县| 双峰县| 嘉禾县| 芜湖县| 西乌| 萨嘎县| 东方市| 罗甸县| 长垣县| 河西区| 雷州市| 和田市| 台安县| 汝州市| 新竹县| 阳高县| 新乡市| 滨州市| 六枝特区| 视频| 阳泉市| 旅游| 都匀市| 沐川县| 邹平县| 望城县| 如皋市| 平乡县| 手机| 景洪市| 诏安县| 海伦市| 肃宁县| 峨眉山市| 柳江县| 宁海县| 贺兰县|