當你開發iOS應 用時,會常用到不少第三方開源類庫,好比JSONKit,AFNetWorking等等。可能某個類庫又用到其餘類庫,因此要使用它,必須得另外下載 其餘類庫,而其餘類庫又用到其餘類庫,「子子孫孫無窮盡也」,這也許是比較特殊的狀況。總之小編的意思就是,手動一個個去下載所需類庫十分麻煩。另一種 常見狀況是,你項目中用到的類庫有更新,你必須得從新下載新版本,從新加入到項目中,十分麻煩。若是能有什麼工具能解決這些惱人的問題,那將「善莫大 焉」。因此,你須要 CocoaPods。git
CocoaPods應該是iOS最經常使用最有名的類庫管理工具了,上述兩個煩人的問題,經過cocoaPods,只須要一行命令就 能夠徹底解決,固然前提是你必須正確設置它。重要的是,絕大部分有名的開源類庫,都支持CocoaPods。因此,做爲iOS程序員的咱們,掌握 CocoaPods的使用是必不可少的基本技能了。程序員
如今的mac系統已經默認安裝好Ruby環境,那麼下載和安裝CocoaPods將十分簡單,只須要一行命令。在Terminator(也就是終端)中輸入如下命令:github
sudo gem install cocoapods
可是,在終端中敲入這個命令以後,會發現半天沒有任何反應。緣由是那堵牆阻擋了cocoapods.org。swift
解決辦法是,咱們能夠用淘寶的Ruby鏡像來訪問cocoapods。按照下面的順序在終端中敲入依次敲入命令:vim
$ gem sources --remove https://rubygems.org/ //等有反應以後再敲入如下命令 $ gem sources -a http://ruby.taobao.org/
爲了驗證你的Ruby鏡像是而且僅是taobao,能夠用如下命令查看:xcode
$ gem sources -l
只有在終端中出現下面文字才代表你上面的命令是成功的:ruby
*** CURRENT SOURCES *** http://ruby.taobao.org/
這時候,你再次在終端中運行:服務器
$ sudo gem install cocoapods
等上十幾秒鐘,CocoaPods就能夠在你本地下載而且安裝好了,再也不須要其餘設置。網絡
爲了肯定CocoaPods是否可使用,能夠用CocoaPods的搜索功能驗證一下。在終端中輸入:app
$ pod search AFNetworking
過一段時間以後(可能會比較久),你會在終端中看到一些紅色的錯誤信息,以下:
Setting up CocoaPods master repo
[!] /usr/bin/Git clone 'https://github.com/CocoaPods/Specs.git' master --depth=1
Cloning into 'master'...
error: RPC failed; result=52, HTTP code = 0
fatal: The remote end hung up unexpectedly
這說明CocoaPods還不能正常使用,須要更新pod,下載它的一些依賴包;在終端中輸入:
$ pod setup
過一段時間以後,你會在終端中看到跟上面一樣的紅色的錯誤信息。
敲入以上命令時,小編終端上是這個樣子的(因爲太長,僅截取前面一部分):
這說明某些環境緣由致使pod更新不了,可能緣由有,1)gem版本過低;2)github沒法連接;3).cocoapods目錄下的配置信息錯誤。咱們能夠一個一個來排除,
首先更新gem到最新版本,在終端中輸入:
$ sudo gem update --system
而後檢查是否能夠ping通github,在終端中輸入:
$ ping github.com
而後查看pob repo list:
$ pod repo list
結果顯示0 repos,說明沒有安裝成功;
刪除.cocoapods目錄,從新下載pod更新:
$ cd ~/.cocoapods/
注意,這段文字不是小編憑空生成的,能夠在AFNetworking的github頁面找到。這兩句文字的意思是,當前 AFNetworking支持的iOS最高版本是iOS 7.0, 要下載的AFNetworking版本是2.0。打開AFNetworking類庫在GitHub地址:https://github.com/AFNetworking/AFNetworking,在首頁中你會找到如下信息,紅框中的內容就是Podfile中的內容:
而後保存退出。vim環境下,保存退出命令是:
:wq
這時候,你會發現你的項目目錄中,出現一個名字爲Podfile的文件,並且文件內容就是你剛剛輸入的內容。注意,Podfile文件應該和你的工程文件.xcodeproj在同一個目錄下。
這時候,你就能夠利用CocoPods下載AFNetworking類庫了。仍是在終端中的當前項目目錄下,運行如下命令:
$ pod install
可能會出現幾種錯誤信息,以下圖:
第一種錯誤:
這個錯誤是由於你的Podfile文件沒有建立到項目目錄下,檢測你的項目路徑是否正確;
第二種錯誤:
訪問github出錯,須要配置dns服務器,有時候github打不開,就必須用8.8.8.8這個公網的dns服務器,其餘的dns服務器,不知道爲什麼解析github就不太行;配置方式以下:
由於是在你的項目中導入AFNetworking,這就是爲何這個命令須要你進入你的項目所在目錄中運行。
運行上述命令以後,小編的終端出現如下信息:
EricmatoMacBook-Pro:CocoaPodsDemo ericwang$ pod install Analyzing dependencies Downloading dependencies Installing AFNetworking (2.0.2) Generating Pods project Integrating client project [!] From now on use `CocoaPodsDemo.xcworkspace`.
注意最後一句話,意思是:之後打開項目就用 CocoaPodsDemo.xcworkspace 打開,而不是以前的.xcodeproj文件。不然沒法關聯pod下來的類庫。
你也許會鬱悶,爲何會出現.xcodeproj文件呢。這正是你剛剛運行$ pod install
命令產生的新文件。除了這個文件,你會發現還多了另一個文件「Podfile.lock」和一個文件夾「Pods」。 點擊 CocoaPodsDemo.xcworkspace 打開以後工程以後,你會驚喜地發現,AFNetwoking已經成功導入項目了!
如今,你就能夠開始使用AFNetworking.h啦。能夠稍微測試一下,在你的項目任意代碼文件中輸入:
#import <AFNetworking.h> 或者 #import "AFNetworking.h"
而後編譯,看看是否出錯。若是你嚴格按照小編上述的步驟來,是不可能出錯的啦。
至此,CocoPods的第一個應用場景講述完畢。其實過程是十分簡單的。總結一下就是:
`$ pod install
.下面,繼續講述第二種使用場景。
你也許曾經遇到過(特別是新手iOS開發者)這種狀況,好不容易在GitHub上找到一份代碼符合本身想需求,興沖沖下載下來, 一編譯,傻眼了,發現有各類各樣錯誤。一看,原來是缺失了各類其餘第三方類庫。這時候莫慌,你再仔細一看,會發現你下載的代碼包含了Podfile。沒 錯,這意味着你能夠用CocoaPods很方便下載所須要的類庫。
下面,以代碼 UAAppReviewManager 爲例來講明如何正確編譯運行一個包含CocoPods類庫的項目。
UAAppReviewManager是一個可以讓你方便地將提醒用戶評分的功能加入你的應用中。當你去 UAAppReviewManager的GitHub地址下載這份代碼以後,打開Example工程 (UAAppReviewManagerExample),編譯,你會發現Xcode報告一大堆錯誤,基本都是說你編譯的這份代碼找不到某某頭文件,這就 意味着你要成功編譯UAAppReviewManager的Example代碼,必須先導入一些第三方類庫。同時你會發如今 UAAppReviewManagerExample文件夾下面有三個跟CocosPods相關的文件(文件 夾):Podfile,Podfile.lock和Pods,以下圖:
這時候,打開終端,進入UAAppReviewManagerExample所在的目錄,也就是和Podfile在同一目錄下,和場景1同樣,輸入如下命令(因爲已經有Podfile,因此不須要再建立Podfile):
$ pod update
過幾秒(也許須要十幾秒,取決於你的網絡情況)以後,終端出現:
Analyzing dependencies Fetching podspec for `UAAppReviewManager` from `../` Downloading dependencies Installing UAAppReviewManager (0.1.6) Generating Pods project Integrating client project [!] From now on use `UAAppReviewManagerExample.xcworkspace`.
這時候,再回到UAAppReviewManagerExample文件夾看一看,會看到多了一個文件UAAppReviewManagerExample.xcworkspace:
根據終端的信息提示,你之後就需用新產生的UAAppReviewManagerExample.xcworkspace來運行這個Example代碼了。
打開UAAppReviewManagerExample.xcworkspace,編譯運行,成功!以下圖:
注意,這裏有個小問題,若是剛剛你不是輸入$ pod update
,而是輸入$ pod install
,會發現類庫導入不成功,而且終端出現下面提示:
[!] Required version (UAAppReviewManager (from `../`)) not found for `UAAppReviewManager`. Available versions: 0.1.6
這裏的意思大概是Podfile文件過時,類庫有升級,可是Podfile沒有更改。$ pod install
只會按照Podfile的要求來請求類庫,若是類庫版本號有變化,那麼將獲取失敗。可是 $ pod update
會更新全部的類庫,獲取最新版本的類庫。並且你會發現,若是用了 $ pod update
,再用 $ pod install
就成功了。
那你也許會問,何時用 $ pod install
,何時用 $ pod update
呢,我又不知道類庫有沒有新版本。好吧,那你每次直接用 $ pod update
算了。或者先用 $ pod install
,若是不行,再用 $ pod update
。