关于cocoapods安装与使用的总结

昨天晚上研究了很入的cocoapods,在各大论坛也看过了很多方法,这里把之前的方法做一个总结。

这里我把自己遇到的一些问题,大概的说了一下。也让广告初学者少走弯路。

先是来自code4app的文章:http://code4app.com/article/cocoapods-install-usage

这里讲述了cocoapods是什么,以及作用,还是搬过来吧。

CocoaPods是什么?

当你开发iOS应用时,会经常使用到很多第三方开源类库,比如JSONKit,AFNetWorking等等。可能某个类库又用到其他类库,所以要使用它,必须得另外下载其他类库,而其他类库又用到其他类库,“子子孙孙无穷尽也”,这也许是比较特殊的情况。总之小编的意思就是,手动一个个去下载所需类库十分麻烦。另外一种常见情况是,你项目中用到的类库有更新,你必须得重新下载新版本,重新加入到项目中,十分麻烦。如果能有什么工具能解决这些恼人的问题,那将“善莫大焉”。所以,你需要 CocoaPods。

CocoaPods应该是iOS最常用最有名的类库管理工具了,上述两个烦人的问题,通过cocoaPods,只需要一行命令就可以完全解决,当然前提是你必须正确设置它。重要的是,绝大部分有名的开源类库,都支持CocoaPods。所以,作为iOS程序员的我们,掌握CocoaPods的使用是必不可少的基本技能了

下面就介绍了如何安装与使用:

安装前需要先升级Ruby版本:

  1.先使用下面命令升级Ruby版本:

$gem update --system    (没有反应就在前面加个sudo)

  2.等待更新完成后,然后通过gem命令来下载安装CocoaPods:

$gem install cocoapods

更新使用:
// sudo gem install 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/

这时候,你再次在终端中运行:

$ sudo gem install cocoapods

等上十几秒钟,CocoaPods就可以在你本地下载并且安装好了,不再需要其他设置。

--------------------------------------------------------------------------------------------

执行pod install 命令(安装第三方库)

出现Setting up CocoaPods master repo,说明Cocoapods在将它的信息下载到 ~/.cocoapods里;

cd  到该目录里,用du -sh *命令来查看文件大小,每隔几分钟查看一次,这个目录最终大小是100多M,就是完成了 

--------------------------------------------------------------------------------------------

 // 安装完毕后调用下面命令,进行CocoaPods设置: 

// $pod setup

还有一点需要注意,pod setup在执行时,会输出Setting up CocoaPods master repo,但是会等待比较久的时间。这步其实是Cocoapods在将它的信息下载到 ~/.cocoapods目录下,如果你等太久,可以试着cd到那个目录,用du -sh *来查看下载进度。

这一步会卡很久,网速慢的话等着恼火。

可以这样做:找一台安好了的电脑,cd到该目录下,用open .命令打开。把里面的repos文件复制过来。。经测试是可以用的。

很多时候,在安装gem的过程中会出现找不到资源的error,我们需要从另外一个gem服务器下载安装。
 
通过gem sources命令配置源,或通过修改Gemfile中的source语句可以实现。

常用的源
http://rubygems.org/
http://gems.github.com
http://gems.rubyforge.org
http://ruby.taobao.org 国内应该找个比较靠谱了,适合安装大多数常见的gem

显示当前使用的sources
gem sources

添加一个source
gem sources -a url地址

删除一个source
gem sources -r url地址

更新source cache
gem sources -u
 
3、检查CocoaPods是否成功安装,打开终端
$which pod
//你将会看到类似这样的输出:
/usr/bin/pod
如果命令行简单的返回提示,或显示pod not found,表示Cocoapods没有成功安装。

   执行完成上述命令后,表示安装成功!下面将讲述如何使用CocoaPods。

场景1:利用CocoaPods,在项目中导入AFNetworking类库

AFNetworking类库在GitHub地址是:https://github.com/AFNetworking/AFNetworking

为了确定AFNetworking是否支持CocoaPods,可以用CocoaPods的搜索功能验证一下。在终端中输入:

$ pod search AFNetworking

过几秒钟之后,你会在终端中看到关于AFNetworking类库的一些信息

4、开始使用CocoaPods,打开终端
$cd 你xcode项目所在的文件夹  //一定要记住先进入你的工程目录
$touch Podfile
$open -e Podfile  
当然也可以
$vim Podfile  // 建议用这个命令
在文本编辑器里,按a进入编辑状态,输入:
   
 platform :ios, '7.0'             //目标平台与版本
pod "AFNetworking", "~> 2.0" 
//项目所有需要引入和安装的第三方库清单,一个一排
    //这里注意上面一排是单引号,下面一排是双引号
注意,这段文字不是小编凭空生成的,可以在AFNetworking的github页面找到。这两句文字的意思是,当前AFNetworking支持的iOS最高版本是iOS 7.0, 要下载的AFNetworking版本是2.0。
保存关闭

然后保存退出。vim环境下,保存退出命令是:wq

//输入完成,退出insert模式,按Esc,然后输入:wq保存退出

5、安装第三方库
$pod install 
 
如果不行
pod install  换成pod install --verbose --no-repo-update这个命令,前面的命令被墙了 
6、等待安装
第一次安装会看到下面这句话卡住了很久 
Setting up CocoaPods master repo
不要着急,其他他正在慢慢爬,我第一次用时也以为是挂了,但其实……
打开终端
$cd ~/.cocoapods/
$du -sh *
//会显示下载了多少m哦,着急的话就隔几秒du -sh一下吧
7、安装完成
[!] From now on use `xxxxxxxxxxxxx.xcworkspace`.
Cocoapods会在你的项目目录中创建一堆新文件,但你主需要关心后缀为.xcworkspace的文件,用Xcode打开。现在有一个Pods项目在你的项目工作区,以及在Pods文件夹放着每一个你引入的库,

  这里要注意的一点是,如果不调用创建Podfile命令就直接调用pod install命令。将会提示“

[!] No `Podfile' found in the current working directory.”

    如果Podfile中添加了新库,可以使用下面命令进行更新:

  pod update

     现在,你的所有第三方库都已经下载完成并且设置好了编译参数和依赖,你只需要记住如下2点即可: 

    1、使用CocoaPods生成的 .xcworkspace 文件来打开工程,而不是以前的 .xcodeproj 文件。  
     2、每次更改了Podfile文件,你需要重新执行一次pod install或者pod update(优先使用)命令 。

现在,你就可以开始使用AFNetworking.h啦。可以稍微测试一下,在你的项目任意代码文件中输入:

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

场景2:如何正确编译运行一个包含CocoPods类库的项目

你也许曾经遇到过(特别是新手iOS开发者)这种情况,好不容易在GitHub上找到一份代码符合自己想需求,兴冲冲下载下来,一编译,傻眼了,发现有各种各样错误。一看,原来是缺失了各种其他第三方类库。这时候莫慌,你再仔细一看,会发现你下载的代码包含了Podfile。没错,这意味着你可以用CocoaPods很方便下载所需要的类库。

下面,小编以代码 UAAppReviewManager 为例来说明如何正确编译运行一个包含CocoPods类库的项目。

UAAppReviewManager是一个能够让你方便地将提醒用户评分的功能加入你的应用中。当你去UAAppReviewManager的GitHub地址下载这份代码之后,打开Example工程(UAAppReviewManagerExample),编译,你会发现Xcode报告一大堆错误,基本都是说你编译的这份代码找不到某某头文件,这就意味着你要成功编译UAAppReviewManager的Example代码,必须先导入一些第三方类库。同时你会发现在UAAppReviewManagerExample文件夹下面有三个跟CocosPods相关的文件(文件夹):Podfile,Podfile.lock和Pods,

这时候,打开终端,进入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:

根据终端的信息提示,你以后就需用新产生的UAAppReviewManagerExample.xcworkspace来运行这个Example代码了。

打开UAAppReviewManagerExample.xcworkspace,编译运行,成功!

注意,这里有个小问题,如果刚刚你不是输入$ 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

 

P.s.1 上面的每一步都有可能出现问题,但大部分问题都是因为大局域网的原因,用一个网速稳定的境外VPN可破。

 

P.s.2 如果上面因为权限问题安装失败,必须每次都要删除

rm -rf /Users/loginnanme/Library/Caches/CocoaPods/

因为这个缓存中会存下你的github的东西,造成每次都调用上次权限问题的缓存。

 
P.s.3关于Podfile文件编辑时,第三方库版本号的各种写法:
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的版本,相当于>=0.1.2并且<0.2.0
pod ‘AFNetworking’, ‘~>0.1′     //使用大于等于0.1但小于1.0的版本
pod ‘AFNetworking’, ‘~>0′     //高于0的版本,写这个限制和什么都不写是一个效果,都表示使用最新版本

参考:
http://geeklu.com/2013/06/cocoapods-101/
http://www.raywenderlich.com/12139/introduction-to-cocoapods

 

原文地址:https://www.cnblogs.com/endtel/p/4704709.html