注:本文内容摘抄自 http://blog.csdn.net/lizhongfu2013/article/details/26384029 内容做了些许修改以及更新。
iOS开发时,项目中会引用许多第三方库,CocoaPods(https://github.com/CocoaPods/CocoaPods)可以用来方便的统一管理这些第三方库。
由于网上的教程基本都大同小异,但细节之处还不是很完善,所以借机会在这里补充下:
注:要使用CocoaPods,那就要下载安装它,而下载安装CocoaPods需要Ruby环境
当前安装环境为Mac mini 10.10.3 Mac OS 本身自带Ruby,但还是更新一下保险,因为我第一次安装在没有更新Ruby的情况下就失败了。
1-1 查看下当前ruby版本:打开终端输入 ruby -v(确实安装了,不过用这个版本接下来工作失败了,所以更新下ruby)
1-2 更新ruby
终端输入如下命令(把Ruby镜像指向taobao,避免被墙,你懂得)
1、gem sources --remove https://rubygems.org/ (该地址被墙了)
2、gem sources -a https://ruby.taobao.org/
3、gem sources -l (用来检查使用替换镜像位置成功)
最新操作细则参照:RubyGems 镜像 - 淘宝网
终端输入:sudo
gem install cocoapods
3-1 新建一个项目,名字PodTest
3-2 在终端中,cd到项目总目录(注意:包含PodTest文件夹、PodTest.xcodeproj、PodTestTest的那个总目录)
例如: cd /Users/KingKong/Desktop/PodTest
3-3 建立Podfile(配置文件)
输入 touch Podfile
接着上一步,终端输入 vim Podfile
键盘输入 i,进入编辑模式,输入
platform :ios, '7.0'
pod 'MBProgressHUD', '~> 0.8'
然后按Esc,并且输入“ :”号进入vim命令模式,然后在冒号后边输入wq
注意:键盘输入 :后,才能输入wq。回车后发现PodTest项目总目录中多一个Podfile文件
激动人心的时刻到了:确定终端cd到项目总目录,然后输入 pod install,等待一会,大约3分钟。
查看项目根目录:
注意:现在打开项目不是点击 PodTest.xodeproj了,而是点击 PodTest.xcworkspace
对于工程发生的变化,有几点需要说明:
a、第三方库会以成静态库方式引入工程使用
CocoaPods会将所有的第三方库以target的方式组成一个名为Pods的工程,该工程就放在刚才新生成的Pods目录下。整个第三方库工程会生成
一个名称为libPods.a的静态库提供给工程使用。
b、xcworkspace(PodTest.xcworkspace)的作用是管理工程和第三方库
PodTest工程和Pods工程被以workspace的形式组织和管理。
打开项目后看到项目结构并且测试一下:
运行结果:
这就需要修改Podfile了,就是用vim编辑的那个保存在项目根目录中的文件,修改完了Podfile文件,需要重新执行一次pod install命令。
例如:
platform :ios
pod 'JSONKit', '~> 1.4'
pod 'AFNetworking', '~> 2.0'
终端输入命令:pod search UI
疯了!我怎么查找这么大众的关键字,好多库~~
然后重新编辑Podfile文件,按照之前的步骤,把更多的库都导入项目!
1 KingKong-Pro:~ kingkong$ cd /Users/KingKong/Desktop/TestProject 2 KingKong-Pro:TestProject kingkong$ touch Podfile
编辑好Podfile文件后,就可以执行pod install第三方导入了(详见:补充第1条),CocoaPods就开始为我们做下载源码、配置依赖关系、
引入需要的framework等一些列工作。
a、如果新建一个Target,命名为Second,并且Second与Test两个Target所需要的第三方支持相同,也就是使用相同的Pods依赖库,则可以使用
link_with关键字:
1 link_with 'Test', 'Second' 2 platform :ios 3 platform :ios, ‘9.0’ 4 pod 'AFNetworking', '~> 2.0'
b、如果不同的Target需要不同的依赖库,则可以
1 platform :ios 2 target :'Test' do 3 pod 'Reachability' 4 pod 'SBJson' 5 pod 'AFNetworking' 6 end 7 8 target :'Second' do 9 pod 'OpenUDID' 10 end
重新打开一个终端,然后pod install,不要sudo pod install。
Analyzing dependencies
Fetching podspec for `UAAppReviewManager` from `..`
[!] Unable to satisfy the following requirements:
- `UAAppReviewManager (from `..`)` required by `Podfile`
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后,
再重新$sudo pod install一下就好了。
如果编译的时候出现权限问题,对工程文件夹$sudo chmod 777 path-to-project-folder/*
$sudo chown 777 path-to-project-folder/*
在TARGETS -> Search Paths -> User Header Search Paths 中 写入 ${SRCROOT}再将后面参数改为recursive:
当新增加一个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
若果Podfile中指定的依赖库版本不是写死的,当对应的依赖库有了更新,无论有没有Podfile.lock文件都会去获取Podfile文件描述的允许获取到的最新依赖库版本。
1 pod 'AFNetworking' //不显式指定依赖库版本,表示每次都获取最新版本 2 pod 'AFNetworking', '2.0' //只使用2.0版本 3 pod 'AFNetworking', '> 2.0' //使用高于2.0的版本 4 pod 'AFNetworking', '>= 2.0' //使用大于或等于2.0的版本 5 pod 'AFNetworking', '< 2.0' //使用小于2.0的版本 6 pod 'AFNetworking', '<= 2.0' //使用小于或等于2.0的版本 7 pod 'AFNetworking', '~> 0.1.2' //使用大于等于0.1.2但小于0.2的版本 8 pod 'AFNetworking', '~>0.1' //使用大于等于0.1但小于1.0的版本 9 pod 'AFNetworking', '~>0' //使用最新版本,与不显示指定依赖库版本相同
唐巧大神这里有更多内容,其中介绍了pod制作及Podfile.lock的相关内容《用CocoaPods做iOS程序的依赖管理》
如果pod install之后,一直停留在Updating local specs repositories,可以试一试 pod install --verbose --no-repo-update,原因是pod install被墙了