CocoaPods 安裝與使用教程

如何下載和安裝CocoaPods?

在安裝CocoaPods前,須要在本地安裝Ruby環境。安裝教程原文:https://ruby-china.org/wiki/install_ruby_guide。(對於Ruby這個是什麼東西,Mr 聶(本人)也不是很瞭解,你只要知到想要安裝前就必須先安裝Ruby就妥妥沒問題了)。ios

系統需求

首先肯定操做系統環境,不建議在 Windows 上面搞,因此你須要用:git

  • Mac OS X 
  • 任意 Linux 發行版本(Ubuntu,CentOS, Redhat, ArchLinux ...)

強烈新手使用 Ubuntu 省掉沒必要要的麻煩!github

如下代碼區域,帶有 $ 打頭的表示須要在控制檯(終端)下面執行(不包括 $ 符號)vim

步驟0 - 安裝系統須要的包

# For Mac 
# 先安裝 [Xcode](http://developer.apple.com/xcode/) 開發工具,它將幫你安裝好 Unix 環境須要的開發包
# 而後安裝 [Homebrew](http://brew.sh)
ruby -e "$(curl -fsSL https://raw.github.com/mxcl/homebrew/go/install)"

步驟1 - 安裝 RVM

RVM 是幹什麼的這裏就不解釋了,後面你將會慢慢搞明白。api

$ curl -L https://get.rvm.io | bash -s stable

期間可能會問你sudo管理員密碼,以及自動經過homebrew安裝依賴包,等待一段時間後就能夠成功安裝好 RVM。xcode

而後,載入 RVM 環境(新開 Termal 就不用這麼作了,會自動從新載入的)ruby

$ source ~/.rvm/scripts/rvm

檢查一下是否安裝正確bash

$ rvm -v
rvm 1.22.17 (stable) by Wayne E. Seguin <wayneeseguin@gmail.com>, Michal Papis <mpapis@gmail.com> [https://rvm.io/]

步驟2 - 用 RVM 安裝 Ruby 環境

$ rvm install 2.0.0

一樣繼續等待漫長的下載,編譯過程,完成之後,Ruby, Ruby Gems 就安裝好了。網絡

步驟3 - 設置 Ruby 版本

RVM 裝好之後,須要執行下面的命令將指定版本的 Ruby 設置爲系統默認版本app

$ rvm 2.0.0 --default

一樣,也能夠用其餘版本號,前提是你有用 rvm install 安裝過那個版本

這個時候你能夠測試是否正確

$ ruby -v
ruby 2.0.0p247 (2013-06-27 revision 41674) [x86_64-darwin13.0.0]

$ gem -v
2.1.6

$ gem source -r https://rubygems.org/
$ gem source -a https://ruby.taobao.org

步驟4 - 安裝 Rails 環境

上面 3 個步驟事後,Ruby 環境就安裝好了,接下來安裝 Rails

$ gem install rails

而後測試安裝是否正確

$ rails -v
Rails 3.2.13

 

假如你在本地已經安裝好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/

上面全部的命令完成之時,在小編的終端上是這個的樣子:

Figure 1

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

$ sudo gem install cocoapods

等上十幾秒鐘,CocoaPods就能夠在你本地下載而且安裝好了,再也不須要其餘設置。

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

Figure 2

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

如何使用CocoaPods?

好了,安裝好CocoPods以後,接下來就是使用它。所幸,使用CocoPods和安裝它同樣簡單,也是經過一兩行命令就能夠搞定。

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

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

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

爲了肯定AFNetworking是否支持CocoaPods,能夠用CocoaPods的搜索功能驗證一下。在終端中輸入:

$ pod search AFNetworking

過幾秒鐘以後,你會在終端中看到關於AFNetworking類庫的一些信息。好比:

Figure 3

這說明,AFNetworking是支持CocoaPods,因此咱們能夠利用CocoaPods將AFNetworking導入你的項目中。

首先,咱們須要在咱們的項目中加入CocoaPods的支持。你能夠跟隨小編的步驟,先利用Xcode建立一個名字CocoaPodsDemo的項目,用於如下的教程。建立好以後,在繼續下一步以前,小編先截圖,看看項目沒有支持CocoaPods時的項目Xcode目錄結構:

Figure 4

上圖等一下要跟項目支持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目錄結構以下圖:

Figure 5

你會驚喜地發現,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,以下圖:

Figure 6

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

Figure 7

根據終端的信息提示,你之後就需用新產生的UAAppReviewManagerExample.xcworkspace來運行這個Example代碼了。

打開UAAppReviewManagerExample.xcworkspace,編譯運行,成功!以下圖:

Figure 8

注意,這裏有個小問題,若是剛剛你不是輸入$ 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

固然,若是你以爲小編上面的敘述有問題,或者你有補充,能夠發郵件給小編:admin@code4app.com 。

另外,若是你但願小編寫其餘iOS技術類的文章,也能夠發信給小編。

以上原文來至:http://code4app.com/article/cocoapods-install-usage#cocoapods

相關文章
相關標籤/搜索