1. 程式人生 > >【IOS學習】CocoaPods安裝使用及配置私有庫

【IOS學習】CocoaPods安裝使用及配置私有庫

如何安裝?

1.安裝ruby環境,新增淘寶ruby映象

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

2.檢視是否設定成功:

$ gem sources -l

3.然後安裝cocoapods:

$ sudo gem install cocoapods

4.檢視cocoapods是否支援某個類庫

$ pod search 類庫名,支援模糊查詢(如:AFNetworking)

如何使用?

  • 在專案根目錄下新建一個“Podfile”的檔案(記住一定得叫這個名兒,而且木有後綴)

注:Podfile也可以放在任何位置,但是需要在Podfile頂部使用”xcodeproj”關鍵字指定工程的路徑,如下:

Podfile指明xcodeproj

Podfile指明xcodeproj

但是執行pod install命令後,生成的檔案放在了Podfile所在的目錄.

  • 編輯Podfile檔案輸入以下資訊

platform :iOS, ‘7.0’\\所有庫支援的IOS最低版本
pod ‘AFNetworking’, ‘~> 2.0’\\版本號

注:有些第三方庫需要指明:platform 支援的IOS最低版本,否則在pod install時會報錯,如下圖,提示AFNetworking最低支援IOS6.0和OS X 10.8

cocoapods指明ios版本

cocoapods指明ios版本

  • 然後在專案podfile所在目錄下執行:(會在你當前專案中匯入podfile所配置的庫,所以要在專案目錄下執行)

$ pod install

注意上述命令執行完畢後終端輸出的最後一段話,意思就是以後開啟專案就用CocoaPodsDemo.xcworkspace 開啟,而不是之前的.xcodeproj檔案。

[!] From now on use `CocoaPodsDemo.xcworkspace`.

經過以上步驟後,我們現在可以開啟CocoaPodsDemo.xcworkspace啟動我們的新工程了.新工程中已經通過cocoapods引入並配置好了我們剛在podfile寫的需要依賴的第三方庫了.

引入第三方庫後找不到標頭檔案?

在專案的Targe-Build Settings-Search Paths-User Header Searcj Paths中新增

${SRCROOT} 值為 recursive

如下圖:

cocoapods配置標頭檔案

cocoapods配置標頭檔案

如何編譯從github上checkout下來的一個已包含CocoPods類庫的專案?

開啟終端進入你所下載專案的根目錄,執行以下命令,後會得到上面的那句話:

$ pod update

等待命令執行完畢後,同樣最後會輸出

[!] From now on use `xxxxx.xcworkspace`.

如何刪除cocopods?

  1. 刪除工程資料夾下的Podfile、Podfile.lock及Pods資料夾
  2. 刪除xcworkspace檔案
  3. 使用xcodeproj檔案開啟工程,刪除Frameworks組下的Pods.xcconfig及libPods.a引用
  4. 在工程設定中的Build Phases下刪除Check Pods Manifest.lock及Copy Pods Resources
刪除cocoapods

刪除cocoapods

CocoaPods常用命令

1、pod install

根據Podfile檔案指定的內容,安裝依賴庫,如果有Podfile.lock檔案而且對應的Podfile檔案未被修改,則會根據Podfile.lock檔案指定的版本安裝。

每次更新了Podfile檔案時,都需要重新執行該命令,以便重新安裝Pods依賴庫。

2、pod update

若果Podfile中指定的依賴庫版本不是寫死的,當對應的依賴庫有了更新,無論有沒有Podfile.lock檔案都會去獲取Podfile檔案描述的允許獲取到的最新依賴庫版本。

3、pod search

命令格式為:

$ pod search 類庫名,支援模糊查詢(如:AFNetworking)

pod search功能

pod search功能

紅框中的資訊為AFNetworking 最新版本,Version中顯示了歷史版本,根據這些資訊來編寫我們的Podfile檔案如:

pod ‘AFNetWorking’, ‘~> 2.2.4′

這句話具體含義是什麼呢?
當我們通過cocopods引入依賴庫時,需要顯示或隱式註明引用的依賴庫版本,具體寫法和表示含義如下

pod ‘AFNetworking’      //不顯式指定依賴庫版本,表示每次都獲取最新版本
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’     //高於0的版本,寫這個限制和什麼都不寫是一個效果,都表示使用最新版本

4、pod setup

用於跟新本地電腦上的儲存的Pods依賴庫tree。由於每天有很多人會建立或者更新Pods依賴庫,這條命令執行的時候會相當慢,還請耐心等待。我們需要經常執行這條命令,否則有新的Pods依賴庫的時候執行pod search命令是搜不出來的。

①多個target中使用相同的Pods依賴庫

比如,名稱為CocoaPodsTest的target和Second的target都需要使用Reachability、SBJson、AFNetworking三個Pods依賴庫,可以使用link_with關鍵字來實現,將Podfile寫成如下方式:

link_with ‘CocoaPodsTest’, ‘Second’
platform :ios
pod ‘Reachability’,  ‘~> 3.0.0’
pod ‘SBJson’, ‘~> 4.0.0’

platform :ios, ‘7.0’
pod ‘AFNetworking’, ‘~> 2.0’

這種寫法就實現了CocoaPodsTest和Second兩個target共用相同的Pods依賴庫。

②不同的target使用完全不同的Pods依賴庫

CocoaPodsTest這個target使用的是Reachability、SBJson、AFNetworking三個依賴庫,但Second這個target只需要使用OpenUDID這一個依賴庫,這時可以使用target關鍵字,Podfile的描述方式如下:

target :’CocoaPodsTest’ do
platform :ios
pod ‘Reachability’,  ‘~> 3.0.0’
pod ‘SBJson’, ‘~> 4.0.0’

platform :ios, ‘7.0’
pod ‘AFNetworking’, ‘~> 2.0′
end

target :’Second’ do
pod ‘OpenUDID’, ‘~> 1.0.0’
end

其中,do/end作為開始和結束識別符號。

Podfile.lock檔案

在使用CocoaPods,執行完pod install之後,會生成一個Podfile.lock檔案。這個檔案看起來跟我們關係不大,實際上絕對不應該忽略它。
該檔案用於儲存已經安裝的Pods依賴庫的版本,通過CocoaPods安裝了SBJson、AFNetworking、Reachability三個POds依賴庫以後對應的Podfile.lock檔案內容為:

PODS:
– AFNetworking (2.1.0):
– AFNetworking/NSURLConnection
– AFNetworking/NSURLSession
– AFNetworking/Reachability
– AFNetworking/Security
– AFNetworking/Serialization
– AFNetworking/UIKit
– AFNetworking/NSURLConnection (2.1.0):
– AFNetworking/Reachability
– AFNetworking/Security
– AFNetworking/Serialization
– AFNetworking/NSURLSession (2.1.0):
– AFNetworking/NSURLConnection
– AFNetworking/Reachability (2.1.0)
– AFNetworking/Security (2.1.0)
– AFNetworking/Serialization (2.1.0)
– AFNetworking/UIKit (2.1.0):
– AFNetworking/NSURLConnection
– Reachability (3.0.0)
– SBJson (4.0.0)

DEPENDENCIES:
– AFNetworking (~> 2.0)
– Reachability (~> 3.0.0)
– SBJson (~> 4.0.0)

SPEC CHECKSUMS:
AFNetworking: c7d7901a83f631414c7eda1737261f696101a5cd
Reachability: 500bd76bf6cd8ff2c6fb715fc5f44ef6e4c024f2
SBJson: f3c686806e8e36ab89e020189ac582ba26ec4220

COCOAPODS: 0.29.0

Podfile.lock檔案最大得用處在於多人開發。當團隊中的某個人執行完pod install命令後,生成的Podfile.lock檔案就記錄下了當時最新Pods依賴庫的版本,這時團隊中的其它人check下來這份包含Podfile.lock檔案的工程以後,再去執行pod install命令時,獲取下來的Pods依賴庫的版本就和最開始使用者獲取到的版本一致。如果沒有Podfile.lock檔案,後續所有使用者執行pod install命令都會獲取最新版本的SBJson,這就有可能造成同一個團隊使用的依賴庫版本不一致,這對團隊協作來說絕對是個災難!
在這種情況下,如果團隊想使用當前最新版本的SBJson依賴庫,有兩種方案:

  1. 更改Podfile,使其指向最新版本的SBJson依賴庫;
  2. 執行pod update命令;

鑑於Podfile.lock檔案對團隊協作如此重要,我們需要將它新增到版本管理中。

如何製作自己的Cocopods庫

1.在github上新建一個工程

github上新建pod工程

github上新建pod工程

license型別

正規的倉庫都應該有一個license檔案,Pods依賴庫對這個檔案的要求更嚴,是必須要有的。因此最好在這裡讓github建立一個,也可以自己後續再建立。我使用的license型別是MIT。

把專案clone到本地然後在根目錄下新建MyPodDemo.podspec

或使用命令

$ pod spec create MyPodDemo

Spec檔案編寫:

Pod::Spec.new do |s|
 s.name = "MyPodDemo"
 s.version = "0.0.1"
 s.summary = "A short description of MyPodDemo."
 s.description = <<-DESC
 A longer description of MyPodDemo in Markdown format.
 * Think: Why did you write this? What is the focus? What does it do?
 * CocoaPods will be using this to generate tags, and improve search results.
 * Try to keep it short, snappy and to the point.
 * Finally, don't worry about the indent, CocoaPods strips it!
 DESC
 s.homepage = "https://github.com/goingta/MyPodDemo"
 s.license = "MIT"
 s.author = { "goingta" => "[email protected]" }
 s.source = { :git => "https://github.com/goingta/MyPodDemo.git", :tag => "0.0.1" }
 s.source_files = "MyPodDemo/Src", "MyPodDemo/Src/**/*.{h,m}"
 s.requires_arc = true
 # s.framework = "SomeFramework"
 # s.frameworks = "SomeFramework", "AnotherFramework"
 # s.library = "iconv"
 # s.libraries = "iconv", "xml2"
 # s.dependency "JSONKit", "~> 1.4"
 # s.dependency "AFNetworking", "~> 2.2.4"
 end

自解析:

 name: 匯入pod後的目錄名
 version: 當前版本號
 deployment_target: 配置的target
 prefix_header_file: 預編譯標頭檔案路徑,將該檔案的內容插入到Pod的pch檔案內
 source: 來源的具體路徑,是http連結還是本地路徑
 requires_arc: 是否需要arc
 source_files: 指定該目錄下包含哪些檔案
 其他可選引數還包括:
 dependency: 指定依賴,如果依賴的庫不存在或者依賴庫的版本不符合要求將會報錯
 libraries: 指定匯入的庫,比如sqlite3
 frameworks: 指定匯入的framework
 weak_frameworks: 弱連結,比如說一個專案同時相容iOS6和iOS7,但某一個framework只在iOS7上有,這時候如果用強連結,那麼在iOS7上執行就會crash,使用weak_frameworks可以避免這種情況。

整個podspec語法是一個巢狀結構從Pod::Spec.new do |s|到最後一個end是最大的迴圈,表示整個podspec匯入的檔案。中間每一個subspec到end結束是一個子目錄,Pods會為每個subspec建立一個邏輯目錄,相當於Xcode的group概念。|**|中間是subspec的名字,可以隨便命名,但後面使用的名稱必須一致。

萬用字元說明

a{bb,bc}def.{h,m}表示四個檔案abbdef.h abbdef.m abcdef.h abcdef.m

*.{h,m,mm}表示所有的.h .m .mm檔案
Class/**/*.{h,m}表示Class目錄下的所有.h .m檔案

寫完podspec檔案後使用pod spec lint驗證spec是否合格,有error則需要修改

spec檔案驗證

spec檔案驗證

上傳程式碼至github

上傳podspec檔案到CocoaPods倉庫(fork一下,修改完成後在push上去等待稽核)

將我們剛剛生成的MyPodDemo.spec 檔案上傳到Cocoapods官方specs倉庫中 :
連結為:https://github.com/CocoaPods/Specs

私有庫實現,編寫podfile

如果由於某些原因我們編寫的庫不能公開,但是又想使用pods來進行管理,要怎麼辦呢?

首先我們要將我們剛剛在github上建的倉庫改為Private(不然還用Public搞毛啊)

然後修改我們專案的podfile,與已加入Cocopods倉庫的公有庫相比我們只需要指明私有庫低git地址,如下:

platform :ios, '6.0'
pod 'MyPodDemo', :git => 'https://github.com/goingta/MyPodDemo.git' //私有庫
pod 'CocoaLumberjack'//公有庫

CocoaPods 使用語義版本控制 – Semantic Versioning 命名約定來解決對版本的依賴。由於衝突解決系統建立在非重大變更的補丁版本之間,這使得解決依賴關係變得容易很多。例如,兩個不同的 pods 依賴於 CocoaLumberjack 的兩個版本,假設一個依賴於2.3.1,另一個依賴於 2.3.3,此時衝突解決系統可以使用最新的版本 2.3.3,因為這個可以向後與 2.3.1 相容。

但這並不總是有效。有許多第三方庫並不使用這樣的約定,這讓解決方案變得非常複雜。

當然,總會有一些衝突需要手動解決。如果一個庫依賴於 CocoaLumberjack 的 1.2.5,另外一個庫則依賴於 2.3.1,那麼只有終端使用者通過明確指定使用某個版本來解決衝突。

配置非ARC檔案(8.5號補充)

前幾天專案中由於歷史原因,導致有一個私有的pods庫中某幾個檔案是在非ARC時代寫的,如果要進行修改工程量浩大,於是乎要對這幾個檔案單獨處理,這幾個檔案不使用arc其他檔案使用arc,網上查了一些資料,只需要對source_file進行修改並排除那幾個不使用ARC的檔案就可以了,大致修改如下:

Pod::Spec.new do |s|
 s.name = "MyPodDemo"
 s.version = "0.0.1"
 s.summary = "A short description of MyPodDemo.
 s.homepage = "https://github.com/goingta/MyPodDemo"
 s.license = "MIT"
 s.author = { "goingta" => "[email protected]" }
 s.source = { :git => "https://github.com/goingta/MyPodDemo.git", :tag => "0.0.1" }
 s.source_files = "MyPodDemo"
 non_arc_files = 'MyPodDemo/NoArcFile1.{h,m}','MyPodDemo/NoArcFile2.{h,m}'
 s.requires_arc = true

 s.exclude_files = non_arc_files
 s.subspec 'no-arc' do |sna|
 sna.requires_arc = false
 sna.source_files = non_arc_files
 end
end

回退Cocoapods歷史版本(2015.3.17號補充)

檢視當前安裝了哪些版本

gem list --local | grep cocoapods

如果你安裝了多個版本(如0.35和0.20.2)那麼你將看到

cocoapods (0.34, 0.20.2)
cocoapods-core (0.33, 0.20.2)
cocoapods-downloader (0.2.0, 0.1.2)

先刪除已經裝過的版本(可能有幾個,解除安裝的時候會讓你輸入1,2..n選擇解除安裝那個版本

sudo gem uninstall cocoapods

或者強制解除安裝某一個版本

gem uninstall cocoapods -v 0.20.2

安裝某一個版本

sudo gem install cocoapods -v 0.35.0

處理 Use the `$(inherited)` flag 異常(2015.6.03補充)

有時候在pod update之後會遇到下面錯誤:

 - Use the `$(inherited)` flag, or
 - Remove the build settings from the target.

雖然對專案編譯沒什麼影響,但是看著還是挺不舒服的.解決辦法就是

找到工程的 targets 點選工程名  Build Settings -> Other linker flags -> 新增 $(inherited)

相關推薦

IOS學習CocoaPods安裝使用配置私有

如何安裝? 1.安裝ruby環境,新增淘寶ruby映象 $ gem sources --remove https://rubygems.org/ //等有反應之後再敲入以下命令 $ gem sources -a http://ruby.taobao.org/ 2

Linux JDK安裝配置 (tar.gz版)

ubuntu logs 環境 pat source alt 修改 8.0 添加 安裝環境   Linux(Ubuntu 版) JDK安裝   tar.gz為解壓後就可以使用的版本,這裏我將使用jdk-8u65-linux-x64.tar.gz版,安裝到/usr/java/下

MongoDB安裝配置

.org root 終端 配置 conn tin serve cal 數據文件 一、MongoDB安裝 1、下載並解壓 wget https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel62-3.2.0.tgz

MAC日常使用—JDK安裝配置

前言      由於工作變動,小編最近吃飯的傢伙也換成了 Mac 筆記本,下面來介紹下Mac本的使用。 正文 一、 安裝JDK     1、 首先,檢視電腦上是否安裝了JDK。      在window

MAC日常使用— MAVEN安裝配置

前言      這次和大家分享下MAC電腦中maven的安裝及配置。 正文 1、下載Maven 2、maven 解壓到安裝目錄 3、開啟終端,輸入vim ~/.bash_profile,編輯bash

IOS學習iPhone螢幕尺寸、解析度適配

1.iPhone尺寸規格 裝置 iPhone 寬 Width 高 Height 對角線 Diagonal 邏輯解析度(point) Scale Factor 裝置解析度(pixel) PPI 3GS 2.4

CentOS6.5MySQL安裝配置

配置 entos alt tro images .com centos ges mys 1./etc/my.cnf 這是mysql的主配置文件 2、數據存放位置 3、錯誤存放位置 【CentOS6.5】MySQL安裝和配置

iOS 開發:CocoaPods 安裝問題 ERROR: Error installing cocoapods: activesupport requires Ruby version>=2.2.2

iOS 開發:CocoaPods 安裝以及 ERROR:  Error installing cocoapods: activesupport requires Ruby version >= 2.2.2. 今天用新的Mac筆記本安裝coco

mysql學習linux安裝mysql,使用install指令碼方式 (二)

本文介紹Linux下MySQL 5.6.27 安裝; 1、下載地址https://cdn.mysql.com/archives/mysql-5.6/mysql-5.6.27-linux-glibc2.5-x86_64.tar.gz 2、解壓tar -zxf mysql-5.6.27-linux-glibc

mysql學習linux安裝mysql,使用install腳本方式 (二)

6.2 學習 sta ini 開機 serve 方式 mysql學習 ref 本文介紹Linux下MySQL 5.6.27 安裝; 1、下載地址https://cdn.mysql.com/archives/mysql-5.6/mysql-5.6.27-linux-glibc

深度學習ResNet解讀程式碼實現

簡介 ResNet是何凱明大神在2015年提出的一種網路結構,獲得了ILSVRC-2015分類任務的第一名,同時在ImageNet detection,ImageNet localization,COCO detection和COCO segmentation等任務中均獲得了第一名,在當

PHP除錯PHPStorm 安裝配置 XDebug 除錯工具 - 圖文教程

背景: 寫程式碼不會除錯那與搬磚何異?!雖然 PHP 是指令碼語言,但是找 bug 、分析程式碼還是要靠除錯啊! 本文測試環境 xampp v3.2.2(32位) Windows 10 企業版 Intel® Core™ i5-5300U CPU

Spring訊息RabbitMq安裝簡單應用(二)

前言: 埋頭苦寫。先把官方文件翻譯過來。整個流程跑一遍。上一篇文章,【Spring訊息】RabbitMq安裝及簡單應用(一),把點對點發送訊息寫完了。之前雖然也可以一個生產者多個消費者,但是一條訊息只能被一個消費者處理,所以是點對點。這篇文章來講講釋出訂閱,一對多。一條訊息

機器學習Windows10安裝tensorflow(附)

在Windows10專業版下安裝Tensorflow cpu版 完全按照官方文件的說明即可在windows下安裝tensorflow的cpu或gpu版本。 (官方文件 https://www.tensorflow.org/get_started/get_started)

深度學習Caffe2安裝 ubuntu16.04

1.介紹 一個輕量級的深度學習框架,商用專案上面貌似用的比較多,廢話不多說,看看怎麼裝 2.安裝 應為官網流程很詳細,直接給出官網連結,針對一些有問題的地方給予補充(算了,我還是

IOS學習到底什麼時候才需要在ObjC的Block中使用weakSelf/strongSelf

Objective C 的 Block 是一個很實用的語法,特別是與GCD結合使用,可以很方便地實現併發、非同步任務。但是,如果使用不當,Block 也會引起一些迴圈引用問題(retain cycle)—— Block 會 retain ‘self’,而 ‘self‘

iOS巔峰之CocoaPods安裝使用的詳細步驟

一、概要 iOS開發時,專案中會引用許多第三方庫,CocoaPods(https://github.com/CocoaPods/CocoaPods)可以用來方便的統一管理這些第三方庫。 二、安裝 由於網上的教程基本都大同小異,但細節之處還不是很完善,所以藉機會在這裡補充下: 注:要使用CocoaPods,那

機器學習神經網路BP推導

1 前向傳播 這裡的推導都用矩陣和向量的形式,計算單個變數寫起來太麻煩。矩陣、向量求導可參見上面參考的部落格,個人覺得解釋得很直接很好。 前向傳播每一層的計算如下: z(l+1)=W(l,l+1)a(l)+b(l,l+1)(1.1) a(l+

ios學習優化 App 的啟動時間實踐 iOS

前言當用戶按下home鍵的時候,iOS的App並不會馬上被kill掉,還會繼續存活若干時間。理想情況下,使用者點選App的圖示再次回來的時候,App幾乎不需要做什麼,就可以還原到退出前的狀態,繼續為使用者服務。這種持續存活的情況下啟動App,我們稱為熱啟動,相對而言冷啟動就是

iOS學習Macbook外接2k顯示器開啟hidpi的方法

一、前言:大家平時用macbook開發的時候一般都喜歡外接一個顯示器開發吧?這裡我用了一臺2k的顯示器,我們要開啟hidpi模式。你們會問到為什麼要開啟hidpi模式呢?我的2k顯示器是2560*1440分別率,如果採用預設的設定,那麼在顯示器上面的字會特別的小。如果我們開啟