CocoaPods安裝和使用教程


CocoaPods安裝和使用教程


http://code4app.com/article/cocoapods-install-usage

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 https://ruby.taobao.org/
爲了驗證你的Ruby鏡像是並且僅是taobao,可以用以下命令查看:

$ gem sources -l
只有在終端中出現下面文字才表明你上面的命令是成功的:

*** CURRENT SOURCES ***

https://ruby.taobao.org/

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

$ sudo gem install cocoapods
等上十幾秒鐘,CocoaPods就可以在你本地下載並且安裝好了,不再需要其他設置。

如果gem太老,可以用如下命令升級gem:

sudo gem update —system


如何使用CocoaPods?

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

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

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

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

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

$ pod search AFNetworking
過幾秒鐘之後,你會在終端中看到關於AFNetworking類庫的一些信息。

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

首先,我們需要在我們的項目中加入CocoaPods的支持。你可以跟隨小編的步驟,先利用Xcode創建一個名字CocoaPodsDemo的項目,用於以下的教程。


你看到這裏也許會問,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”。

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

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

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

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

  1. 先在項目中創建Podfile,Podfile的內容是你想導入的類庫。一般類庫的原作者會告訴你導入該類庫應該如何寫Podfile;
  2. 運行命令:`$ pod install.


CocoaPods specs的鏡像索引

在使用cocoapods進行update或者install的時候,會去更新獲取pod specs。
所有的項目的podspec文件都託管在https://github.com/CocoaPods/Specs上。
第一次執行pod setup時,cocoapods會將這些podspec索引文件更新到本地的 ~/。cocoapods/目錄下,
這個索引文件比較大,國內網絡的問題,更新非常慢。

網上一個博主http://akinliu.github.io/2014/05/03/cocoapods-specs-/ ,對github上的specs倉庫進行了鏡像,
是每10分鐘進行同步一次,基本和主倉庫保持一致。
gitcafe和oschina都是國內服務器,在執行索引更新操作時,快很多。

使用方法:
pod repo remove master
pod repo add master https://gitcafe.com/akuandev/Specs.git
pod repo update

如果想用oschina的鏡像,可以把第二條命令的地址換成oschina的即可。
pod repo add master http://git.oschina.net/akuandev/Specs.git

如果在pod install、或者pod update時,不想升級specs庫,可以增加忽略參數
pod install --no-repo-update
pod update --no-repo-update






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