ios Framework靜態(tài)庫以及上傳私有庫

最近需要將自己項目的公共代碼打包成 Framework 來使用,但是在打包過程中遇到一個問題,就是提取的公共代碼中用到了一些第三方的庫,比如 AFNetworking 等。

創(chuàng)建 Framework 工程

1. 創(chuàng)建打包工程
  • 打開 Xcode 新建一個工程,選擇 Framework & Libray 選項中的 Cocoa Touch Framework
1.png
  • 創(chuàng)建項目名稱公司ID選擇證書
2.png
  • 由于項目需要引入第三方庫,所以需要引入cocopods
  • cd 項目名稱
  • pod init 創(chuàng)建Podfile 文件
  • 編輯Podfile文件
  • pod install 拉去cocopods下的第三方庫
2. 添加公開頭文件
  • 將需要轉(zhuǎn)成靜態(tài)庫的文件導(dǎo)入項目,注意需要保留創(chuàng)建工程自動生成的.h文件,它相當(dāng)于我們平時工程里的pch文件,用于導(dǎo)入頭文件的
  • 選中 Target ,選擇 Build Phases - Headers ,可以看出有三個選項,分別是 Public 、Private 、Project ,把需要公開給別人的 .h 文件拖到 Public 中,把不想公開的,即為隱藏的 .h 文件拖到 Project 中。
3.png
  • 完成上述步驟之后,在默認(rèn)生成的 .h 文件中,我的是 TestFramework.h ,把所有需要暴露的 .h 文件都用 #import <TestFramework/PublicHeader.h>引入,記住一定要將所有需要暴露的 .h 文件都引入,也就是上面 Headers - Public 中加的所有 .h 文件,不然編譯后生成的 .framework 在引用的時候會有警告。
4.png
  • 注意引入第三方庫的頭文件,是在自動生成的.h文件里導(dǎo)入第三方庫,其他文件需要引用第三方庫的文件,則直接引入自動生成的.h文件即可,例如ASAESUtil需要引用第三方庫,則直接導(dǎo)入AESFramework.h文件,如果需要引用的文件不是第三方庫,則直接引用該文件,文件名為<AESFramework/NSData+ASAES.h>類型,如圖所示
7.png
3.添加公開頭文件
  • 選中 Target ,選擇 Build Settings ,Build Active Archiyecture Onluy 設(shè)置為No。
i5.png
  • 選中 Target ,選擇 Build Settings ,在搜索欄搜索 Mach-O Type ,將 Mach-O Type 修改為 Static Library。
6.png

工程打包成 Framework

1. 真機(jī)編譯所有文件
  • 按照下圖將編譯的 Device 選擇為真機(jī) ,然后按下 Command + B 開始編譯,編譯成功后右鍵 Products 文件夾下的 .framework 文件,點擊 show in Finder
8.png
  • 打開后可以看到打包完成的真機(jī) Framework 包。
9.png
2. 模擬器編譯所有文件,將真機(jī)換成模擬器即可
3. 將兩個 Framework 合成
上面有兩個 Framework , 一個是 Debug-iphoneos(真機(jī)) 下的,一個是 Debug-iphonesimulator(模擬器) 下的,需要通過終端命令將兩個 Framework 合為一個模擬器和真機(jī)都可使用的 Framework
  • 打開終端先輸入 lipo -create ,然后輸入 空格
  • 接著將 Debug-iphoneos(真機(jī)) 下的 AESFramework也就是上面框出來的空白文件直接拖到終端,終端會自動顯示路徑。
  • 然后直接將 Debug-iphonesimulator(模擬器) 下的AESFramework也拖到終端。
  • 接著輸入 -output ,然后輸入 空格 。
  • 然后輸入 Debug-iphoneos(真機(jī))的AESFramework 地址后直接回車。
  • 這時候?qū)⒄鏅C(jī)下的AESFramework.framework 就是我們需要的framework靜態(tài)庫了。
  • 但是可以發(fā)現(xiàn)打包完后的 .framework 包里面是沒有 CocoaPods 集成的第三方庫的,所以在使用 .framework 包時,工程中必須也要集成 .framework 包中用到的第三方庫,否則會找不到文件而報錯。
10.png

4.打包完的 Framework

  • 將framework拖入項目中,然后用#import <AESFramework/AESFramework.h> 這種格式引入靜態(tài)庫即可

5.打包完的 Framework 放置私有庫

11.png
  • 將.framework放到 Frameworks文件夾下,修改對應(yīng)的podspec文件,framework靜態(tài)庫的私有庫只需要一個.framework的文件和podspec文件即可和.a靜態(tài)庫的私有庫是有區(qū)別的
Pod::Spec.new do |s|

  s.name         = "ASAESSecurity"
  s.version      = "2.0.3"http://版本號
  s.summary      = "A short description of ASAESSecurity"
  s.description  = <<-DESC

                   DESC

  s.homepage     = "http://EXAMPLE/ASAESSecurity"

  s.license      = "MIT"

  s.author       = { "xx" => "xxx@xx.com" }
  s.platform     = :ios, "8.0"

  s.source       = { :svn => "xxxxxx/cocoapods-svn/", :tag => "#{s.name}/#{s.version}" }//私有庫地址

  s.vendored_frameworks = 'Frameworks/AESFramework.framework' //依賴對應(yīng)的.framework文件
  s.dependency 'xxx' //引用的第三方
  s.requires_arc = true

end
  • 私有庫更新之后,本地項目選擇對應(yīng)的私有庫版本號加入podfile文件中,再終端執(zhí)行pod repo-svn update tags 更新本地tags庫,再執(zhí)行pod install 拉取framework私有庫,頭文件引用也是一樣的#import <AESFramework/AESFramework.h> 這種格式引入
  • 引入.framework 私有庫可能會出現(xiàn)找不到頭文件的報錯
11.png
  • 這時候,我們可以選擇在項目工程的Building setting 里選擇Allow Non-modular includes in Framework Modules 設(shè)置成YES,再運(yùn)行項目,就可以正常運(yùn)行(有個疑問,正常運(yùn)行之后,我講設(shè)置重新改成NO,但是項目依舊可以正常運(yùn)行了,很奇怪,不過總之是成功了)
  • 如果pod install之后發(fā)現(xiàn)私有庫的代碼沒有更新,Cocoapods下的tags庫中的私有庫更新了,可以使用open ~/Library/Caches/Cocoapods 清除Cocoapods緩存
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容