天天看點

CocoaPods安裝和使用及問題:Setting up CocoaPods master repo

目錄

  • CocoaPods是什麼?
  • 如何下載下傳和安裝CocoaPods?
  • 如何使用CocoaPods?
    • 場景1:利用CocoaPods,在項目中導入AFNetworking類庫
    • 場景2:如何正确編譯運作一個包含CocoPods類庫的項目

CocoaPods是什麼?

當你開發iOS應用時,會經常使用到很多第三方開源類庫,比如JSONKit,AFNetWorking等等。可能某個類庫又用到其他類庫,是以要使用它,必須得另外下載下傳其他類庫,而其他類庫又用到其他類庫,“子子孫孫無窮盡也”,這也許是比較特殊的情況。總之小編的意思就是,手動一個個去下載下傳所需類庫十分麻煩。另外一種常見情況是,你項目中用到的類庫有更新,你必須得重新下載下傳新版本,重新加入到項目中,十分麻煩。如果能有什麼工具能解決這些惱人的問題,那将“善莫大焉”。是以,你需要 CocoaPods。

CocoaPods應該是iOS最常用最有名的類庫管理工具了,上述兩個煩人的問題,通過cocoaPods,隻需要一行指令就可以完全解決,當然前提是你必須正确設定它。重要的是,絕大部分有名的開源類庫,都支援CocoaPods。是以,作為iOS程式員的我們,掌握CocoaPods的使用是必不可少的基本技能了。

如何下載下傳和安裝CocoaPods?

在安裝CocoaPods之前,首先要在本地安裝好Ruby環境。至于如何在Mac中安裝好Ruby環境,請google一下,本文不再涉及。

假如你在本地已經安裝好Ruby環境,那麼下載下傳和安裝CocoaPods将十分簡單,隻需要一行指令。在Terminator(也就是終端)中輸入以下指令(注意,本文所有指令都是在終端中輸入并運作的。什麼,你不知道什麼是終端?那請小編吃飯,小編告訴你):

sudo gem install cocoapods      

但是,且慢。如果你在天朝,在終端中敲入這個指令之後,會發現半天沒有任何反應。原因無他,因為那堵牆阻擋了cocoapods.org。(你會問,我靠,這都要牆!是的,小編也納悶。)

但是,是的,又但是(不過是個可喜的“但是”)。我們可以用淘寶的Ruby鏡像來通路cocoapods。按照下面的順序在終端中敲入依次敲入指令:

$ gem sources --remove https://rubygems.org/
//等有反應之後再敲入以下指令
$ gem sources -a http://ruby.taobao.org/      

為了驗證你的Ruby鏡像是并且僅是taobao,可以用以下指令檢視:

$ gem sources -l      

隻有在終端中出現下面文字才表明你上面的指令是成功的:

*** CURRENT SOURCES ***

http://ruby.taobao.org/      

上面所有的指令完成之時,在小編的終端上是這個的樣子:

CocoaPods安裝和使用及問題:Setting up CocoaPods master repo

這時候,你再次在終端中運作:

$ sudo gem install cocoapods      

等上十幾秒鐘,CocoaPods就可以在你本地下載下傳并且安裝好了,不再需要其他設定。

敲入以上指令時,小編終端上是這個樣子的(由于太長,僅截取前面一部分):

CocoaPods安裝和使用及問題:Setting up CocoaPods master repo

看到這裡,你心裡會不會說,我靠!太爽了,這麼容易就可以下載下傳并且安裝好了!是的,小編也是這麼想的。CocoPods就是這麼簡單,使用也十分簡單。繼續往下看吧。

--------------------------------------------------------------------------------------------

執行pod install 指令

出現Setting up CocoaPods master repo,說明Cocoapods在将它的資訊下載下傳到 ~/.cocoapods裡;

cd  到該目錄裡,用du -sh *指令來檢視檔案大小,每隔幾分鐘檢視一次,這個目錄最終大小是100多M,就是完成了 

--------------------------------------------------------------------------------------------

如何使用CocoaPods?

好了,安裝好CocoPods之後,接下來就是使用它。所幸,使用CocoPods和安裝它一樣簡單,也是通過一兩行指令就可以搞定。

小編在這裡用兩種使用場景來具體說明如何使用CocoaPods。

場景1:利用CocoaPods,在項目中導入AFNetworking類庫

AFNetworking類庫在GitHub位址是:https://github.com/AFNetworking/AFNetworking

為了确定AFNetworking是否支援CocoaPods,可以用CocoaPods的搜尋功能驗證一下。在終端中輸入:

$ pod search AFNetworking      

過幾秒鐘之後,你會在終端中看到關于AFNetworking類庫的一些資訊。比如:

CocoaPods安裝和使用及問題:Setting up CocoaPods master repo

這說明,AFNetworking是支援CocoaPods,是以我們可以利用CocoaPods将AFNetworking導入你的項目中。

首先,我們需要在我們的項目中加入CocoaPods的支援。你可以跟随小編的步驟,先利用Xcode建立一個名字CocoaPodsDemo的項目,用于以下的教程。建立好之後,在繼續下一步之前,小編先截圖,看看項目沒有支援CocoaPods時的項目Xcode目錄結構:

CocoaPods安裝和使用及問題:Setting up CocoaPods master repo

上圖等一下要跟項目支援CocoaPods之後的項目Xcode目錄結構做對比。

你看到這裡也許會問,CocoaPods為什麼能下載下傳AFNetworking呢,而不是下載下傳其他類庫呢?這個問題的答案是,有個檔案來控制CocoaPods該下載下傳什麼。這個檔案就叫做“Podfile”(注意,一定得是這個檔案名,而且沒有字尾)。你建立一個Podfile檔案,然後在裡面添加你需要下載下傳的類庫,也就是告訴CocoaPods,“某某和某某和某某某,快到碗裡來!”。每個項目隻需要一個Podfile檔案。

好吧,廢話少說,我們先建立這個神奇的PodFile。在終端中進入(cd指令)你項目所在目錄,然後在目前目錄下,利用vim建立Podfile,運作:

$ vim Podfile      

然後在Podfile檔案中輸入以下文字:

platform :ios, '7.0'
pod "AFNetworking", "~> 2.0"      

注意,這段文字不是小編憑空生成的,可以在AFNetworking的github頁面找到。這兩句文字的意思是,目前AFNetworking支援的iOS最高版本是iOS 7.0, 要下載下傳的AFNetworking版本是2.0。

然後儲存退出。vim環境下,儲存退出指令是:

:wq      

這時候,你會發現你的項目目錄中,出現一個名字為Podfile的檔案,而且檔案内容就是你剛剛輸入的内容。注意,Podfile檔案應該和你的工程檔案.xcodeproj在同一個目錄下。

這時候,你就可以利用CocoPods下載下傳AFNetworking類庫了。還是在終端中的目前項目目錄下,運作以下指令:

$ pod install      

因為是在你的項目中導入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檔案。

你也許會郁悶,為什麼會出現.xcodeproj檔案呢。這正是你剛剛運作

$ pod install

指令産生的新檔案。除了這個檔案,你會發現還多了另外一個檔案“Podfile.lock”和一個檔案夾“Pods”。 點選 CocoaPodsDemo.xcworkspace 打開之後工程之後,項目Xcode目錄結構如下圖:

CocoaPods安裝和使用及問題:Setting up CocoaPods master repo

你會驚喜地發現,AFNetwoking已經成功導入項目了(紅框部分)!

現在,你就可以開始使用AFNetworking.h啦。可以稍微測試一下,在你的項目任意代碼檔案中輸入:

#import <AFNetworking.h>
或者
#import "AFNetworking.h"      

然後編譯,看看是否出錯。如果你嚴格按照小編上述的步驟來,是不可能出錯的啦。

至此,CocoPods的第一個應用場景講述完畢。别看小編寫了這麼多,其實過程是十分簡單的。總結一下就是:

  1. 先在項目中建立Podfile,Podfile的内容是你想導入的類庫。一般類庫的原作者會告訴你導入該類庫應該如何寫Podfile;
  2. 運作指令:

    `$ pod install

    .

下面,小編繼續講述第二種使用場景。

場景2:如何正确編譯運作一個包含CocoPods類庫的項目

你也許曾經遇到過(特别是新手iOS開發者)這種情況,好不容易在GitHub上找到一份代碼符合自己想需求,興沖沖下載下傳下來,一編譯,傻眼了,發現有各種各樣錯誤。一看,原來是缺失了各種其他第三方類庫。這時候莫慌,你再仔細一看,會發現你下載下傳的代碼包含了Podfile。沒錯,這意味着你可以用CocoaPods很友善下載下傳所需要的類庫。

下面,小編以代碼 UAAppReviewManager 為例來說明如何正确編譯運作一個包含CocoPods類庫的項目。

UAAppReviewManager是一個能夠讓你友善地将提醒使用者評分的功能加入你的應用中。當你去UAAppReviewManager的GitHub位址下載下傳這份代碼之後,打開Example工程(UAAppReviewManagerExample),編譯,你會發現Xcode報告一大堆錯誤,基本都是說你編譯的這份代碼找不到某某頭檔案,這就意味着你要成功編譯UAAppReviewManager的Example代碼,必須先導入一些第三方類庫。同時你會發現在UAAppReviewManagerExample檔案夾下面有三個跟CocosPods相關的檔案(檔案夾):Podfile,Podfile.lock和Pods,如下圖:

CocoaPods安裝和使用及問題:Setting up CocoaPods master repo

這時候,打開終端,進入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:

CocoaPods安裝和使用及問題:Setting up CocoaPods master repo

根據終端的資訊提示,你以後就需用新産生的UAAppReviewManagerExample.xcworkspace來運作這個Example代碼了。

打開UAAppReviewManagerExample.xcworkspace,編譯運作,成功!如下圖:

CocoaPods安裝和使用及問題:Setting up CocoaPods master repo

注意,這裡有個小問題,如果剛剛你不是輸入

$ 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

好了,小編就啰嗦到這裡吧。上述都隻是CocoaPods的最基本用法。要繼續研究CocoaPods其他進階用法,請點選這裡CocoaPods Wiki。