一、概要
iOS開發時,項目中會引用許多第三方庫,CocoaPods(https://github.com/CocoaPods/CocoaPods)可以用來友善的統一管理這些第三方庫(從一個坑出來,又進了另一個坑而已……)。
二、安裝
由于網上的教程基本都大同小異,但細節之處還不是很完善,是以借機會在這裡補充下:
注:要使用CocoaPods,那就要下載下傳安裝它,而下載下傳安裝CocoaPods需要Ruby環境
1、Ruby環境搭建
目前安裝環境為Mac mini 10.8.5。Mac OS本身自帶Ruby,但還是更新一下保險,因為我第一次安裝在沒有更新Ruby的情況下就失敗了。
a 檢視下目前ruby版本:打開終端輸入 ruby -v(确實安裝了,不過用這個版本接下來工作失敗了,是以更新下ruby)
[objc] view plain copy

- ritekiMac-mini:PodTest lucky$ ruby -v
- ruby 1.8.7 (2012-02-08 patchlevel 358) [universal-darwin12.0]
- ritekiMac-mini:PodTest lucky$
b 更新ruby
終端輸入如下指令(把Ruby鏡像指向taobao,避免被牆,你懂得)
gem sources --remove https://rubygems.org/
gem sources -a http://ruby.taobao.org/
gem sources -l (用來檢查使用替換鏡像位置成功)
[objc] view plain copy

- ritekiMac-mini:~ lucky$ gem sources --remove https://rubygems.org/
- https://rubygems.org/ removed from sources
- ritekiMac-mini:~ lucky$ gem sources -a http://ruby.taobao.org/
- http://ruby.taobao.org/ added to sources
- ritekiMac-mini:~ lucky$ gem sources -l
- *** CURRENT SOURCES ***
補充:(2016-01-20更新)
淘寶已經關閉HTTP協定的景象服務,改為HTTPS協定。
淘寶ruby位址:https://ruby.taobao.org/
2、下載下傳安裝 CocoaPods
終端輸入:sudo gem install cocoapods
[html] view plain copy

- ritekiMac-mini:~ lucky$ sudo gem install cocoapods
- CHANGELOG:
- ## 0.32.1
- ##### Bug Fixes
- * Fixed the Podfile `default_subspec` attribute in nested subspecs.
- [Fabio Pelosin][irrationalfab]
- \ [#2050](https://github.com/CocoaPods/CocoaPods/issues/2050)
- Successfully installed cocoapods-0.32.1
- Installing ri documentation for cocoapods-0.32.1
- /System/Library/Frameworks/Ruby.framework/Versions/1.8/usr/lib/ruby/1.8/rdoc/rdoc.rb:280: warning: conflicting chdir during another chdir block
- /System/Library/Frameworks/Ruby.framework/Versions/1.8/usr/lib/ruby/1.8/rdoc/rdoc.rb:287: warning: conflicting chdir during another chdir block
- Done installing documentation for cocoapods after 10 seconds
- 1 gem installed
這樣就下載下傳安裝好了CocoaPods
3、使用CocoaPods
a 建立一個項目,名字PodTest
b 終端中,cd到項目總目錄(注意:包含PodTest檔案夾、PodTest.xcodeproj、PodTestTest的那個總目錄)
[objc] view plain copy

- cd /Users/lucky/Desktop/PodTest
c 建立Podfile(配置檔案)
接着上一步,終端輸入 vim Podfile
鍵盤輸入 i,進入編輯模式,輸入
platform :ios, '7.0'
pod 'MBProgressHUD', '~> 0.8'
然後按Esc,并且輸入“ :”号進入vim指令模式,然後在冒号後邊輸入wq
注意:鍵盤輸入 :後,才能輸入wq。回車後發現PodTest項目總目錄中多一個Podfile檔案
激動人心的時刻到了:确定終端cd到項目總目錄,然後輸入 pod install,等待一會,大約3分鐘。
檢視項目根目錄:
注意:現在打開項目不是點選 PodTest.xodeproj了,而是點選 PodTest.xcworkspace
對于工程發生的變化,有幾點需要說明:
a、第三方庫會以成靜态庫方式引入工程使用
CocoaPods會将所有的第三方庫以target的方式組成一個名為Pods的工程,該工程就放在剛才新生成的Pods目錄下。整個第三方庫工程會生成一個名稱為libPods.a的靜态庫提供給工程使用。
b、xcworkspace(PodTest.xcworkspace)的作用是管理工程和第三方庫
PodTest工程和Pods工程被以workspace的形式組織和管理。
打開項目後看到項目結構并且測試一下:
運作結果:
補充:
1、CocoaPods的基本安裝及使用都詳細的說明了,但還有一些補充,當需要同時導入多個第三方時候怎麼辦 ?
這就需要修改Podfile了,就是用vim編輯的那個儲存在項目根目錄中的檔案,修改完了Podfile檔案,需要重新執行一次pod install指令。
例如:
platform :ios
pod 'JSONKit', '~> 1.4'
pod 'AFNetworking', '~> 2.0'
2、 CocoaPods可以查找你想要的第三方庫
終端輸入指令:pod search UI
瘋了了,我怎麼查找這麼大衆的關鍵字,好多庫~~
然後重新編輯Podfile檔案,按照之前的步驟,把更多的庫都導入項目!
3、上文中“建立Podfile(配置檔案)接着上一步,終端輸入 vim Podfile”步驟,如果不習慣使用vim編輯器,也可以使用linux指令touch,生成一個空的Podfile檔案,然後使用其他的文本編輯器都可以,例如:
[objc] view plain copy

- lizhongfudeMacBook-Pro:~ lizhongfu$ cd /Users/lizhongfu/Desktop/TestProject
- lizhongfudeMacBook-Pro:TestProject lizhongfu$ touch Podfile
編輯好Podfile檔案後,就可以執行pod install第三方導入了(詳見:補充第1條), CocoaPods就開始為我們做下載下傳源碼、配置依賴關系、引入需要的framework等一些列工作。
4、如果已經生成了CocoaPods管理的工程,則可以在Xcode中編輯Podfile,編輯儲存後,别忘記cd到根目錄,調用pod install指令
5、項目存在多個Target的時候,需要配置Podfile檔案來支援新增加的Target,否則隻支援項目預設建立時生成的Target:
a、如果建立一個Target,命名為Second,并且Second與Test兩個Target所需要的第三方支援相同,也就是使用相同的Pods依賴庫,則可以使用
link_with關鍵字:
[objc] view plain copy

- link_with 'Test', 'Second'
- platform :ios
- platform :ios, ‘9.0’
- pod 'AFNetworking', '~> 2.0'
b、如果不同的Target需要不同的依賴庫,則可以
[objc] view plain copy

- platform :ios
- target :'Test' do
- pod 'Reachability'
- pod 'SBJson'
- pod 'AFNetworking'
- end
- target :'Second' do
- pod 'OpenUDID'
- end
6、出現/Library/Ruby/Gems/2.0.0/gems/claide-0.8.1/lib/claide/command.rb:417:in `help!': [!] You cannot run CocoaPods as root. (CLAide::Help)
重新打開一個終端,然後pod install,不要sudo pod install。
7、如果$ pod install時候遇到:
Analyzing dependencies
Fetching podspec for `UAAppReviewManager` from `..`
[!] Unable to satisfy the following requirements:
- `UAAppReviewManager (from `..`)` required by `Podfile`
8、如果要移除Cocoapods,則可以:
a. 删除工程檔案夾下的Podfile、Podfile.lock及Pods檔案夾
b. 删除xcworkspace檔案
c. 使用xcodeproj檔案打開工程,删除Frameworks組下的Pods.xcconfig及libPods.a引用
d. 在工程設定中的Build Phases下删除Check Pods Manifest.lock及Copy Pods Resources
ps:如果将cocoapods內建到工程中後不小心修改或删除了其相關檔案導緻無法便以通過例如:不小心把
Pods.xcconfig給删除了然後出現diff: /../Podfile.lock: No such file or directory,用上面的方法删除cocoapods後,
再重新$sudo pod install一下就好了。
如果編譯的時候出現權限問題,對工程檔案夾$sudo chmod 777 path-to-project-folder/*
$sudo chown 777 path-to-project-folder/*
9、當庫正常導入,但還是找不到相關頭檔案,則可以:
在TARGETS -> Search Paths -> User Header Search Paths 中 寫入 ${SRCROOT}再将後面參數改為recursive:
10、Xcode - ld: library not found for -lPods
當新增加一個Target,并且pod install後,由于建立項目是預設建立的Target的Build Phases中引用了舊的.a,例如libPods.a,當新增加Targget後,libPods.a已經變成了libPods-Test.a,而新增加的Target名字為Second,依賴的.a為libPods-Second.a。是以libPods.a此時已經不再被引用,并且不會被生成,如果任何地方引用了就會報錯,解決辦法是出現問題的Target的Build Phases中删除無用的.a引用,例如libPods.a
11、pod update
若果Podfile中指定的依賴庫版本不是寫死的,當對應的依賴庫有了更新,無論有沒有Podfile.lock檔案都會去擷取Podfile檔案描述的允許擷取到的最新依賴庫版本。
12、在引用第三方,如果想明确第三方版本号的時候,還有一些小細節:
[objc] view plain copy

- pod 'AFNetworking' //不顯式指定依賴庫版本,表示每次都擷取最新版本 (<span style="color: rgb(50, 62, 50); font-family: Arial; font-size: 14px; line-height: 26px;">11、</span><span style="color: rgb(50, 62, 50); font-family: Arial; font-size: 14px; line-height: 26px;">pod update</span>)
- pod 'AFNetworking', '2.0' //隻使用2.0版本
- pod 'AFNetworking', '> 2.0' //使用高于2.0的版本
- pod 'AFNetworking', '>= 2.0' //使用大于或等于2.0的版本
- pod 'AFNetworking', '< 2.0' //使用小于2.0的版本
- pod 'AFNetworking', '<= 2.0' //使用小于或等于2.0的版本
- pod 'AFNetworking', '~> 0.1.2' //使用大于等于0.1.2但小于0.2的版本
- pod 'AFNetworking', '~>0.1' //使用大于等于0.1但小于1.0的版本
- pod 'AFNetworking', '~>0' //使用最新版本,與不顯示指定依賴庫版本相同
巧大神這裡有更多内容,其中介紹了pod制作及Podfile.lock的相關内容《用CocoaPods做iOS程式的依賴管理》
13、如果pod install之後,一直停留在Updating local specs repositories,可以試一試 pod install --verbose --no-repo-update,原因是pod install被牆了
14、(2016年6月11日)The dependency 'xxx' is not used in any concrete target
在Podfile檔案中需要明确指出使用第三方庫的target,例如:
platform:ios,'7.0'
pod 'MJRefresh', '~> 3.1.0'
pod 'SDWebImage', '~> 3.7.6'
pod 'SVProgressHUD', '~> 2.0.3'
pod 'AFNetworking', '~> 3.1.0'
改為:
platform:ios,'7.0'
target "MyTarget" do
pod 'MJRefresh', '~> 3.1.0'
pod 'SDWebImage', '~> 3.7.6'
pod 'SVProgressHUD', '~> 2.0.3'
pod 'AFNetworking', '~> 3.1.0'
end
pod update 試了還可以用
pod install 被牆了,請大家換成pod install --verbose --no-repo-update
更新10.11後使用CocoaPod出現-bash: pod: command not found 解決辦法
1.更新10.11後,運作pod指令出現:
<code class="bash" style="padding: 0px; font-family: Menlo, Monaco, Consolas, 'Courier New', monospace; font-size: 12px; border: none; background-color: transparent;">-bash: pod: <span class="hljs-built_in" style="color: rgb(38, 139, 210);">command</span> not found</code>
解決辦法:
<code class="sql" style="padding: 0px; font-family: Menlo, Monaco, Consolas, 'Courier New', monospace; font-size: 12px; border: none; background-color: transparent;">sudo gem <span class="hljs-operator"><span class="hljs-keyword" style="color: rgb(133, 153, 0);">install</span> -<span class="hljs-keyword" style="color: rgb(133, 153, 0);">n</span> /usr/<span class="hljs-keyword" style="color: rgb(133, 153, 0);">local</span>/<span class="hljs-keyword" style="color: rgb(133, 153, 0);">bin</span> cocoapods</span></code>
2'如果還不能解決,可以使用以下方法再試試:
sudo gem install -n /usr/local/bin cocoapods /
sudo chmod +rx /usr/local/bin
3.遇到如下錯誤可能是因為裝了多個Xcode導緻路徑變了
[!] Unable to add a source with url `https://github.com/CocoaPods/Specs.git` named `master-1`. You can try adding it manually in `~/.cocoapods/repos` or via `pod repo add`.
解決辦法:
sudo xcode-select -switch /Applications/Xcode.app
/Applications/Xcode.app:此部分未Xcode所在路徑,找到Xcode的安裝路徑,拖進來即可
4.
pod》error:The dependency `` is not used in any concrete target
我的原來Podfile的内容是:
platform:ios,'7.0'
pod 'MJRefresh', '~> 3.1.0'
pod 'SDWebImage', '~> 3.7.6'
pod 'SVProgressHUD', '~> 2.0.3'
pod 'AFNetworking', '~> 3.1.0'
修改為:
platform:ios,'7.0'
target "MyTarget" do
pod 'MJRefresh', '~> 3.1.0'
pod 'SDWebImage', '~> 3.7.6'
pod 'SVProgressHUD', '~> 2.0.3'
pod 'AFNetworking', '~> 3.1.0'
end
此處的MyTarget為自己的工程名
5.使用Pod後導緻"_OBJC_CLASS_$_xxx", reference
解決辦法:
在自己的工程Build Phases的Link Binary With Libraries中添加
6.TodayExtension中共用Pod中的庫