CocoaPods安装和使用详细说明

一、安装

要使用CocoaPods,那就要下载安装它,而下载安装CocoaPods需要依赖Ruby环境

Ruby环境搭建

Mac OS本身自带Ruby,但还是更新一下保险,因为我第一次安装在没有更新Ruby的情况下就失败了。

在终端下用以下命令查看下当前ruby版本

ruby -v

更新ruby

终端输入如下命令(把Ruby镜像指向taobao,避免被墙,你懂得)

gem sources --remove https://rubygems.org/ 
gem sources -a https://ruby.taobao.org/ 
gem sources -l  (用来检查使用替换镜像位置成功)

补充:(2016-01-20更新)
淘宝已经关闭HTTP协议的景象服务,改为HTTPS协议。
淘宝ruby地址:https://ruby.taobao.org/
如果使用淘宝地址也无效,则移除淘宝地址,改为这个地址:https://gems.ruby-china.org/

下载安装CocoaPods

终端输入:

sudo gem install cocoapods

不出意外的话就下载安装好了CocoaPods

补充:
安装的时候出现如下问题

ERROR:  While executing gem ... (OpenSSL::SSL::SSLError)
    hostname "upyun.gems.ruby-china.org" does not match the server certificate

原因是之前用的ruby镜像源是淘宝的,已经不能用了,需要切换成https://gems.ruby-china.org/,在终端输入

gem sources —remove https://ruby.taobao.org/
gem sources -a https://gems.ruby-china.org/

如下错误原因是依赖的环境版本过低需要更新

ERROR:  While executing gem ... (Gem::DependencyError)
    Unable to resolve dependencies: cocoapods requires cocoapods-core (= 0.38.2), claide (~> 0.9.1), xcodeproj (~> 0.26.3), cocoapods-downloader (~> 0.9.1), cocoapods-plugins (~> 0.4.2), cocoapods-stats (~> 0.5.3), cocoapods-try (~> 0.4.5), cocoapods-trunk (~> 0.6.1), molinillo (~> 0.3.1)

输入如下命令解决

sudo gem update --system

如果出现这个问题,输入该命令解决:sudo gem install -n /usr/local/bin cocoapods

ERROR:  While executing gem ... (Errno::EPERM)
    Operation not permitted - /usr/bin/xcodeproj
JerrydeMacBook-Pro:~ Jerry.Yao$ sudo gem install -n /usr/local/bin cocoapods

如果出现如下问题,输入命令解决:sudo gem install -n /usr/local/bin cocoapods

ERROR:  While executing gem ... (Errno::EPERM)
    Operation not permitted - /usr/bin/pod

3、使用CocoaPods
a 新建一个项目,名字PodTest

b 终端中,cd到项目总目录(注意:包含PodTest文件夹、PodTest.xcodeproj、PodTestTest的那个总目录)
[objc] view plain copy print?在CODE上查看代码片派生到我的代码片
cd /Users/lucky/Desktop/PodTest

c 建立Podfile(配置文件)
接着上一步,终端输入:
1. pod init #初始化pod
2. touch Podfile #生成podfile文件
3. open Podfile #打开podfile文件
4. 把需要添加的pod库添加到打开的podfile文件里面
5. pod install #安装pod库

激动人心的时刻到了:确定终端cd到项目总目录,然后输入 pod install,等待一会,大约3分钟。

注意:现在打开项目不是点击 PodTest.xodeproj了,而是点击 PodTest.xcworkspace
对于工程发生的变化,有几点需要说明:
a、第三方库会以成静态库方式引入工程使用
CocoaPods会将所有的第三方库以target的方式组成一个名为Pods的工程,该工程就放在刚才新生成的Pods目录下。整个第三方库工程会生成一个名称为libPods.a的静态库提供给工程使用。
b、xcworkspace(PodTest.xcworkspace)的作用是管理工程和第三方库
PodTest工程和Pods工程被以workspace的形式组织和管理。

打开项目后看到项目结构并且测试一下

补充:
1、CocoaPods的基本安装及使用都详细的说明了,但还有一些补充,当需要同时导入多个第三方时候怎么办 ?
这就需要修改Podfile了,就是用vim编辑的那个保存在项目根目录中的文件,修改完了Podfile文件,需要重新执行一次pod install命令。
例如:
platform :ios
pod ‘JSONKit’, ‘~> 1.4’
pod ‘AFNetworking’, ‘~> 2.0’

2、CocoaPods可以查找你想要的第三方库
终端输入命令:pod search xxx

然后重新编辑Podfile文件,按照之前的步骤,把更多的库都导入项目!
3、上文中“建立Podfile(配置文件)接着上一步,终端输入 vim Podfile”步骤,如果不习惯使用vim编辑器,也可以使用linux命令touch,生成一个空的Podfile文件,然后使用其他的文本编辑器都可以,命令:touch Podfile
编辑好Podfile文件后,就可以执行pod install第三方导入了(详见:补充第1条),CocoaPods就开始为我们做下载源码、配置依赖关系、引入需要的framework等一些列工作。
4、如果已经生成了CocoaPods管理的工程,则可以在Xcode中编辑Podfile,编辑保存后,别忘记cd到根目录,调用pod install命令

5、项目存在多个Target的时候,需要配置Podfile文件来支持新增加的Target,否则只支持项目默认建立时生成的Target:
a、如果新建一个Target,命名为Second,并且Second与Test两个Target所需要的第三方支持相同,也就是使用相同的Pods依赖库,则可以使用
link_with关键字:
[objc] view plain copy print?在CODE上查看代码片派生到我的代码片
link_with ‘Test’, ‘Second’
platform :ios
platform :ios, ‘9.0’
pod ‘AFNetworking’, ‘~> 2.0’

b、如果不同的Target需要不同的依赖库,则可以
[objc] view plain copy print?在CODE上查看代码片派生到我的代码片
platform :ios
target :’Test’ do
pod ‘Reachability’
pod ‘SBJson’
pod ‘AFNetworking’
end

target :’Second’ do
pod ‘OpenUDID’
end

6、出现/Library/Ruby/Gems/2.0.0/gems/claide-0.8.1/lib/claide/command.rb:417:in help!': [!] You cannot run CocoaPods as root. (CLAide::Help)
重新打开一个终端,然后pod install,不要sudo pod install。
7、如果$ pod install时候遇到:
Analyzing dependencies
Fetching podspec for
UAAppReviewManagerfrom..
[!] Unable to satisfy the following requirements:
-
UAAppReviewManager (from ..)required byPodfile`
8、如果要移除Cocoapods,则可以:
a. 删除工程文件夹下的Podfile、Podfile.lock及Pods文件夹
b. 删除xcworkspace文件
c. 使用xcodeproj文件打开工程,删除Frameworks组下的Pods.xcconfig及libPods.a引用
d. 在工程设置中的Build Phases下删除Check Pods Manifest.lock及Copy Pods Resources

ps:如果将cocoapods集成到工程中后不小心修改或删除了其相关文件导致无法便以通过例如:不小心把
Pods.xcconfig给删除了然后出现diff: /../Podfile.lock: No such file or directory,用上面的方法删除cocoapods后,
再重新sudopodinstall sudo chmod 777 path-to-project-folder/*
$sudo chown 777 path-to-project-folder/*

9、当库正常导入,但还是找不到相关头文件,则可以:
在TARGETS -> Search Paths -> User Header Search Paths 中 写入 ${SRCROOT}再将后面参数改为recursive:

10、Xcode - ld: library not found for -lPods
当新增加一个Target,并且pod install后,由于创建项目是默认创建的Target的Build Phases中引用了旧的.a,例如libPods.a,当新增加Targget后,libPods.a已经变成了libPods-Test.a,而新增加的Target名字为Second,依赖的.a为libPods-Second.a。所以libPods.a此时已经不再被引用,并且不会被生成,如果任何地方引用了就会报错,解决办法是出现问题的Target的Build Phases中删除无用的.a引用,例如libPods.a

11、pod update
若果Podfile中指定的依赖库版本不是写死的,当对应的依赖库有了更新,无论有没有Podfile.lock文件都会去获取Podfile文件描述的允许获取到的最新依赖库版本。
12、在引用第三方,如果想明确第三方版本号的时候,还有一些小细节:
[objc] view plain copy print?在CODE上查看代码片派生到我的代码片
pod ‘AFNetworking’ //不显式指定依赖库版本,表示每次都获取最新版本 (11、pod update
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’ //使用最新版本,与不显示指定依赖库版本相同

巧大神这里有更多内容,其中介绍了pod制作及Podfile.lock的相关内容《用CocoaPods做iOS程序的依赖管理》
13、如果pod install之后,一直停留在Updating local specs repositories,可以试一试 pod install –verbose –no-repo-update,原因是pod install被墙了

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