一、全新安裝前,先檢查是否有安裝殘留
由於Mac 10.11更改了安全機制,所以cocoapods得安裝和卸載命令也有所改變,
1、如果之前裝過cocopods,最好先卸載掉,卸載命令:
$ sudo gem uninstall cocoapods【Mac 10.10之前】
$ sudo gem uninstall -n /usr/local/bin cocoapods【Mac 10.11之后】
2、先查看本地安裝過的cocopods相關東西【本步驟沒有必要】,命令如下:
$ gem list --local | grep cocoapods
會顯示如下:
cocoapods-core (0.39.0)
cocoapods-downloader (0.9.3)
cocoapods-plugins (0.4.2)
cocoapods-search (0.1.0)
cocoapods-stats (0.6.2)
cocoapods-trunk (0.6.4)
cocoapods-try (0.5.1)
然后逐個刪除吧:
$ sudo gem uninstall cocoapods-core【Mac 10.10之前】
$ sudo gem uninstall -n /usr/local/bin cocoapods-core【Mac 10.11之后】
。。。
二、安裝
由於網上的教程基本都大同小異,但細節之處還不是很完善,所以借機會在這里補充下:
注:要使用CocoaPods,那就要下載安裝它,而下載安裝CocoaPods需要Ruby環境
1、准備工作
當前安裝環境為Mac os 10.11.6。Mac OS本身自帶Ruby,但還是更新一下保險,因為我第一次安裝在沒有更新Ruby的情況下就失敗了。
a) 查看下當前ruby版本:打開終端輸入 ruby -v(確實安裝了,不過用這個版本接下來工作失敗了,所以更新下ruby)(更新方法自己百度。。。)
- chendeMacBook-Air:~ chen$ ruby -v
- ruby 2.3.0p0 (2015-12-25 revision 53290) [x86_64-darwin15]
- chendeMacBook-Air:~ chen$
- chendeMacBook-Air:~ chen$ ruby -v
- ruby 2.3.0p0 (2015-12-25 revision 53290) [x86_64-darwin15]
- chendeMacBook-Air:~ chen$
b)cocoapods鏡像:https://gems.ruby-china.org/ 好像現在不支持淘寶了
終端輸入如下命令(把Ruby鏡像指向Ruby China,避免被牆,你懂得)
$gem sources --remove https://rubygems.org/
$gem sources --add https://gems.ruby-china.org/
$gem sources -l (用來檢查使用替換鏡像位置成功)
- chendeMacBook-Air:~ chen$ gem sources -l
- *** CURRENT SOURCES ***
- https://gems.ruby-china.org/
- chendeMacBook-Air:~ chen$ gem sources -l
- *** CURRENT SOURCES ***
- https://gems.ruby-china.org/
2、下載安裝CocoaPods
終端輸入:sudo gem install -n /usr/local/bin cocoapods
- ......
- Installing ri documentation for cocoapods-0.39.0
- Done installing documentation for cocoapods-try, cocoapods-trunk, cocoapods-stats, cocoapods-search, cocoapods-plugins, cocoapods-downloader, cocoapods-core, cocoapods after 5 seconds
- 8 gems installed
- ......
- Installing ri documentation for cocoapods-0.39.0
- Done installing documentation for cocoapods-try, cocoapods-trunk, cocoapods-stats, cocoapods-search, cocoapods-plugins, cocoapods-downloader, cocoapods-core, cocoapods after 5 seconds
- 8 gems installed
接下來進行安裝,執行:
$ pod setup
Terminal會停留在 Setting up CocoaPods master repo 這個狀態一段時間,是因為要進行下載安裝,而且目錄比較大,需要耐心等待一下.安裝成功后,你會看到: setup completed
這樣就下載安裝好了CocoaPods
/************************************************************************************************************************************/
安裝過程遇到的問題:
1、Ruby版本過低(更新就行了)
2、
- $ pod setup
- Setting up CocoaPods master repo
- [!] /usr/bin/git clone https://github.com/CocoaPods/Specs.git master
- Cloning into ‘master’…
- error: RPC failed; curl 56 SSLRead() return error -36
- fatal: The remote end hung up unexpectedly
- fatal: early EOF
- fatal: index-pack failed
- $ pod setup
- Setting up CocoaPods master repo
- [!] /usr/bin/git clone https://github.com/CocoaPods/Specs.git master
- Cloning into ‘master’…
- error: RPC failed; curl 56 SSLRead() return error -36
- fatal: The remote end hung up unexpectedly
- fatal: early EOF
- fatal: index-pack failed
3、
- $ pod setup
- Setting up CocoaPods master repo
- [!] /usr/bin/git clone https://github.com/CocoaPods/Specs.git master
- Cloning into ‘master’…
- error: RPC failed; curl 56 SSLRead() return error -9806
- fatal: The remote end hung up unexpectedly
- fatal: early EOF
- fatal: index-pack failed
- $ pod setup
- Setting up CocoaPods master repo
- [!] /usr/bin/git clone https://github.com/CocoaPods/Specs.git master
- Cloning into ‘master’…
- error: RPC failed; curl 56 SSLRead() return error -9806
- fatal: The remote end hung up unexpectedly
- fatal: early EOF
- fatal: index-pack failed
4、
- $ pod setup
- Setting up CocoaPods master repo
- [!] /usr/bin/git clone https://github.com/CocoaPods/Specs.git master
- Cloning into ‘master’…
- error: RPC failed; curl 18 transfer closed with outstanding read data remaining
- fatal: The remote end hung up unexpectedly
- fatal: early EOF
- fatal: index-pack failed
- $ pod setup
- Setting up CocoaPods master repo
- [!] /usr/bin/git clone https://github.com/CocoaPods/Specs.git master
- Cloning into ‘master’…
- error: RPC failed; curl 18 transfer closed with outstanding read data remaining
- fatal: The remote end hung up unexpectedly
- fatal: early EOF
- fatal: index-pack failed
解決方法:上面錯誤主要是os10.11+和cocoapods1.0+版本升級的安全機制更改造成的。主要出現在pod setup過程中。且該過程等待時間非常長,所以,你可以在$sudo gem install -n /usr/local/bin cocoapods命令后直接執行$Git clone https://git.coding.net/CocoaPods/Specs.git ~/.cocoapods/repos/master 該過程作用與 pod setup作用相同,作者親測。效果極佳!!!!
如果還不成功!!!!可以同樣的方法安裝正式版v0.39 然后在升級到v1.0版本
gem update --system
sudo gem install -n /usr/local/bin cocoapods --pre
/************************************************************************************************************************************/
三、使用CocoaPods
a 新建一個項目,名字PodTest
b 終端中,cd到項目總目錄(注意:包含PodTest文件夾、PodTest.xcodeproj、PodTestTest的那個總目錄)
- $cd /Users/chen/Desktop/projects/PodTest
c 建立Podfile(配置文件)
接着上一步,終端輸入$vim Podfile
鍵盤輸入 i,進入編輯模式,輸入
platform :iOS, '8.0'
target "PodTest" do
pod 'MBProgressHUD', '~> 1.0.0'
end
然后按Esc,並且輸入“ :”號進入vim命令模式,然后在冒號后邊輸入wq
注意:鍵盤輸入 :后,才能輸入wq。回車后發現PodTest項目總目錄中多一個Podfile文件
激動人心的時刻到了:確定終端cd到項目總目錄,然后輸入 $pod install,等待一會。
查看項目根目錄:
注意:現在打開項目不是點擊 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 JSONKit
瘋了了,我怎么查找這么大眾的關鍵字,好多庫~~
然后重新編輯Podfile文件,按照之前的步驟,把更多的庫都導入項目!
3、上文中“建立Podfile(配置文件)接着上一步,終端輸入 vim Podfile”步驟,如果不習慣使用vim編輯器,也可以使用linux命令touch,生成一個空的Podfile文件,然后使用其他的文本編輯器都可以,例如:
- 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關鍵字:
- link_with 'Test', 'Second'
- platform :ios
- platform :ios, ‘9.0’
- pod 'AFNetworking', '~> 2.0'
b、如果不同的Target需要不同的依賴庫,則可以
- 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、在引用第三方,如果想明確第三方版本號的時候,還有一些小細節:
- 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' //使用最新版本,與不顯示指定依賴庫版本相同
13、如果pod install之后,一直停留在Updating local specs repositories,可以試一試 pod install --verbose --no-repo-update,原因是pod install被牆了
可能出現的錯誤:
一、pod install時報錯:
1、終端報錯:The dependency MBProgressHUD (~> 0.9.2)
is not used in any concrete target.
2、原因:CocoaPods升級到最新版本(包括一些高版本),Podfile文件的內容必須明確指出所用第三方庫的targetName.
3、報錯分析:低版本和高版本寫法不一樣.
低版本:
platform :ios, '8.0'
pod 'MBProgressHUD', '~> 0.9.2'
高版本:
platform :ios, '8.0'
target "targetName" do
pod 'MBProgressHUD', '~> 0.9.2'
end
注意:這里的 targetName 填寫工程的名字。
二、刪除某個框架
方法:
1.打開Podfile文件,刪除JSONKit該行,即:
platform:ios, '7.0'
pod 'AFNetworking', '~> 2.1.0'pod 'JSONKit', '~> 1.5pre'(刪除該行)
pod 'MBProgressHUD', '~> 0.8'
(如果想換成1.1版本,將被刪除的行改成pod 'JSONKit-NoWarning', '~> 1.1'即可)