CocoaPods安裝和使用詳細說明

一、安裝

要使用CocoaPods,那就要下載安裝它,而下載安裝CocoaPods需要依賴Ruby環境

Ruby環境搭建

Mac OS本身自帶Ruby,但還是更新一下保險,因爲我第一次安裝在沒有更新Ruby的情況下就失敗了。

在終端下用以下命令查看下當前ruby版本

ruby -v

更新ruby

終端輸入如下命令(把Ruby鏡像指向taobao,避免被牆,你懂得)

gem sources --remove https://rubygems.org/ 
gem sources -a https://ruby.taobao.org/ 
gem sources -l  (用來檢查使用替換鏡像位置成功)

補充:(2016-01-20更新)
淘寶已經關閉HTTP協議的景象服務,改爲HTTPS協議。
淘寶ruby地址:https://ruby.taobao.org/
如果使用淘寶地址也無效,則移除淘寶地址,改爲這個地址:https://gems.ruby-china.org/

下載安裝CocoaPods

終端輸入:

sudo gem install cocoapods

不出意外的話就下載安裝好了CocoaPods

補充:
安裝的時候出現如下問題

ERROR:  While executing gem ... (OpenSSL::SSL::SSLError)
    hostname "upyun.gems.ruby-china.org" does not match the server certificate

原因是之前用的ruby鏡像源是淘寶的,已經不能用了,需要切換成https://gems.ruby-china.org/,在終端輸入

gem sources —remove https://ruby.taobao.org/
gem sources -a https://gems.ruby-china.org/

如下錯誤原因是依賴的環境版本過低需要更新

ERROR:  While executing gem ... (Gem::DependencyError)
    Unable to resolve dependencies: cocoapods requires cocoapods-core (= 0.38.2), claide (~> 0.9.1), xcodeproj (~> 0.26.3), cocoapods-downloader (~> 0.9.1), cocoapods-plugins (~> 0.4.2), cocoapods-stats (~> 0.5.3), cocoapods-try (~> 0.4.5), cocoapods-trunk (~> 0.6.1), molinillo (~> 0.3.1)

輸入如下命令解決

sudo gem update --system

如果出現這個問題,輸入該命令解決:sudo gem install -n /usr/local/bin cocoapods

ERROR:  While executing gem ... (Errno::EPERM)
    Operation not permitted - /usr/bin/xcodeproj
JerrydeMacBook-Pro:~ Jerry.Yao$ sudo gem install -n /usr/local/bin cocoapods

如果出現如下問題,輸入命令解決:sudo gem install -n /usr/local/bin cocoapods

ERROR:  While executing gem ... (Errno::EPERM)
    Operation not permitted - /usr/bin/pod

3、使用CocoaPods
a 新建一個項目,名字PodTest

b 終端中,cd到項目總目錄(注意:包含PodTest文件夾、PodTest.xcodeproj、PodTestTest的那個總目錄)
[objc] view plain copy print?在CODE上查看代碼片派生到我的代碼片
cd /Users/lucky/Desktop/PodTest

c 建立Podfile(配置文件)
接着上一步,終端輸入:
1. pod init #初始化pod
2. touch Podfile #生成podfile文件
3. open Podfile #打開podfile文件
4. 把需要添加的pod庫添加到打開的podfile文件裏面
5. pod install #安裝pod庫

激動人心的時刻到了:確定終端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 xxx

然後重新編輯Podfile文件,按照之前的步驟,把更多的庫都導入項目!
3、上文中“建立Podfile(配置文件)接着上一步,終端輸入 vim Podfile”步驟,如果不習慣使用vim編輯器,也可以使用linux命令touch,生成一個空的Podfile文件,然後使用其他的文本編輯器都可以,命令: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 print?在CODE上查看代碼片派生到我的代碼片
link_with ‘Test’, ‘Second’
platform :ios
platform :ios, ‘9.0’
pod ‘AFNetworking’, ‘~> 2.0’

b、如果不同的Target需要不同的依賴庫,則可以
[objc] view plain copy print?在CODE上查看代碼片派生到我的代碼片
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
UAAppReviewManagerfrom..
[!] Unable to satisfy the following requirements:
-
UAAppReviewManager (from ..)required byPodfile`
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後,
再重新sudopodinstall 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 print?在CODE上查看代碼片派生到我的代碼片
pod ‘AFNetworking’ //不顯式指定依賴庫版本,表示每次都獲取最新版本 (11、pod update
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被牆了

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章