前言

什么是CocoaPods?

CocoaPods是OS X和iOS下的一个第三类库管理工具,通过CocoaPods工具我们可以为项目添加被称为“Pods”的依赖库(这些类库必须是CocoaPods本身所支持的),并且可以轻松管理其版本。

Cocoapods意义体现在两个方面。

  • 第一,在引入第三方库时它可以自动为我们完成各种各样的配置,包括配置编译阶段、连接器选项、甚至是ARC环境下的-fno-objc-arc配置等。
  • 第二,使用CocoaPods可以很方便地查找新的第三方库,这些类库是比较“标准的”,而不是网上随便找到的,这样可以让我们找到真正好用的类库。

接下来我们将介绍CocoaPods的使用。

下载和安装CocoaPods

CocoaPods是用Ruby写的,所以运行需要安装Ruby环境。Mac中已经自带Ruby环境,这个不用我们担心,如果认为Ruby环境不够新,我们可以先更新,打开终端,输入以下命令:

  1. gem update --system

接下来我们可以安装CocoaPods了,在安装前,我们先做点小动作。

  • 由于安装CocoaPods时我们要访问cocoapods.org,该网站可能被我们大天朝墙了,这样下载安装可能会是龟速,

幸好我们可以用淘宝的Ruby镜像来访问该网站,方法如下:

  1. $ gem sources --remove https://rubygems.org/
  2. $ gem sources -a http://ruby.taobao.org/
  • 成功后,使用以下命令查看:
  1. $ gem sources -l

可以看到替换镜像成功:http://ruby.taobao.org/

  接下来是真正的安装,在终端输入以下命令:

  1. $ sudo gem install cocoapods

安装输出非常长,这里就不贴出来了。

然后使用setup命令配置CocoaPods(这个命令也可以不运行,但是第一次使用pod命令时这个setup过程也会自动执行)

  1. AppledeMacBook-Pro:~ apple$ pod setup
  2. Setting up CocoaPods master repo
  3. Setup completed (read-only access)

这个时间可能比较长,耐心等待下。

使用CocoaPods为工程配置第三方类库

首先打开Xcode新建一个工程,假设为Desktop/CocoaPodsDemo,并且我们要往该工程中导入AFNetworking这个类库。

AFNetworking在Github中的地址为:https://github.com/AFNetworking/AFNetworking

这里也说明了如何使用CocoaPods配置该类库:

以上说明是我们应该如何书写Podfile文件。一般非常流行和成熟的类库都得到了CocoaPods的支持,并且有这个说明。

如何确定CocoaPods是否支持我们想要加入的目标类库?使用Search命令搜索类库名:

  1. $ pod search AFNetworking

如果CocoaPods支持,将会输出搜索到的所有类库版本和信息,以及在Podfile中配置的写法,例如

  1. -> AFNetworking (2.1.0)
  2. A delightful iOS and OS X networking framework.
  3. pod 'AFNetworking', '~> 2.1.0'
  4. - Homepage: https://github.com/AFNetworking/AFNetworking
  5. - Source:   https://github.com/AFNetworking/AFNetworking.git
  6. - Versions: 2.1.0, 2.0.3, 2.0.2, 2.0.1, 2.0.0-RC3, 2.0.0-RC2, 2.0.0-RC1,
  7. 2.0.0, 1.3.3, 1.3.2, 1.3.1, 1.3.0, 1.2.1, 1.2.0, 1.1.0, 1.0RC3, 1.0RC2,
  8. 1.0RC1, 1.0.1, 1.0, 0.9.2, 0.9.1, 0.9.0, 0.7.0, 0.5.1, 0.10.1, 0.10.0 [master
  9. repo]
  10. - Sub specs:
  11. - AFNetworking/Serialization (2.1.0)
  12. - AFNetworking/Security (2.1.0)
  13. - AFNetworking/Reachability (2.1.0)
  14. - AFNetworking/NSURLConnection (2.1.0)
  15. - AFNetworking/NSURLSession (2.1.0)
  16. - AFNetworking/UIKit (2.1.0)

首先在我们的工程目录下创建Podfile文件,该文件用来控制CocoaPods的下载内容,该文件是没有后缀的,每个项目只需要一个Podfile文件;

创建过程:首先cd到工程目录,然后创建Podfile并且使用vim编写:

使用CocoaPods管理第三方库的步骤 在终端中输入步骤中所需的命令

 1.先进入工程所在的文件夹

cd /Users/Documents/Desktop/Frame_test

2.创建 Podfile 文件

vim Podfile

3.进入编辑模式

在终端命令生成Podfile文件之后 按键盘上的字母 i 进入编辑模式

4.在终端进入编辑模式之后输入要用到的第三方库名称

    比如:

platform:ios, '7.0'

pod "AFNetworking", "~>2.1"

5.在将上述步骤完成之后

   先按 esc键 之后是 :(说明按完esc 再输入冒号)接着是输入 wq(保存并退出);输入wq之后回车即可

  

6 导入生成 pod-- 输入pod install

pod install --verbose --no-repo-update

 注意:在终端输入此命令时
      将pod install 替换为 pod install --verbose --no-repo-update

安装完成后,输出信息如下:(有绿色文字提示:说明文件安装成功,在打开工程的时候直接打开:.xcworkspace的工程文件,不再打开原来的工程文件)

打开Build Phases,可以看到CocoaPods已经自动为我们完成了所有设置:

之后我们可以在工程中导入AFNetworking、JSONKit和MBProgressHUD的任意头文件并使用其所有接口了:

  1. #import "ViewController.h"
  2. #import <AFNetworking/AFNetworking.h>
  3. #import <JSONKit-NoWarning/JSONKit.h>
  4. #import <MBProgressHUD/MBProgressHUD.h>

新建Podfile文件并编写要导入的类库信息,打开终端输入pod install命令安装,完成。一切都是如此的方便。

补充

当Cocoapods向项目中增加了一个第三方库的时候,不仅仅只是添加代码,由于每个第三方类库有不同的target,所以每次添加第三方库时,都会有几个文件被写入磁盘,包括Podfile.lock和Manifest.lock文件等。

其中Podfile.lock记录了需要被安装的pod的每个已安装的版本。如果你想知道已安装的pod是哪个版本,可以查看这个文件。

Manifest.lock是每次运行pod install时创建的Podfile.lock文件的副本。

Cocopods -第三方库的管理的更多相关文章

  1. CocoaPods一个Objective-C第三方库的管理利器

    转:http://blog.csdn.net/totogo2010/article/details/8198694 介绍: 开发应用的时候第三方的库是不可缺少的,能提高开发的效率. 一些经常用到的库, ...

  2. 常用iOS第三方库以及XCode插件介绍

    第三方库 CocoaPod CocoaPod并不是iOS上的第三方库 而是大名鼎鼎的第三方库的管理工具 在CocoaPod没有出现之前 第三方库的管理是非常痛苦的 尤其是一些大型的库(比如nimbus ...

  3. 个人常用iOS第三方库以及XCode插件介绍

    第三方库 CocoaPod CocoaPod并不是iOS上的第三方库 而是大名鼎鼎的第三方库的管理工具 在CocoaPod没有出现之前 第三方库的管理是非常痛苦的 尤其是一些大型的库(比如nimbus ...

  4. 【转】个人常用iOS第三方库以及XCode插件介绍 -- 不错

    原文网址:http://adad184.com/2015/07/08/my-favorite-libraries-and-plugins/ 第三方库是现在的程序员离不开的东西 不光是APP开发 基本上 ...

  5. iOS之第三方库以及XCode插件介绍

    前言 第三方库是现在的程序员离不开的东西 不光是APP开发 基本上所有的商业项目 都会或多或少的使用到第三方库 Github上Star>100的开源库数量如下 可以看到JS以绝对的优势排名第一 ...

  6. iOS开发遇到的坑之六--使用cocopods管理第三方库时,编译出现Library not found for -lPods问题的解决办法

    在项目中有时候会遇到Library not found for -lPods(这里的IPods指的是你具体的第三方库)的问题 出现这个错误的原因是:xcode在编译的时候找不到这个库,从而导致项目无法 ...

  7. Xcode工程使用CocoaPods管理第三方库新建工程时出现错误

    工程使用CocoaPods管理第三方库,在新的目录update版本的时候出现如下问题   问题1描述: diff: /../Podfile.lock: No such file or director ...

  8. 创建podSpec,使用pod管理第三方库

    提要: podfile文件会先读取.podspec文件,根据.podspec文件的指向来下载第三方库到项目中. 本文先通过一.二.三项,这三个步骤讲解了如何建立一个.podspec文件在本地.coco ...

  9. iOS开发:在Xcode中用Pods管理第三方库

    之前写了一篇 iOS开发:在Swift中调用oc库 ,今天记录一下如何用Pods的方式来管理第三方库,包括Swift/Object-C的库. 在这之前请先查阅Guides.CocoaPods如何使用的 ...

随机推荐

  1. Cloud Test 在手,宕机时让您不再措手不及

    1月28日,Github 上午 10:04 分宕机了,导致全球各地的用户不能访问.官方回复可能是网络中断引起的,到 10:28 分已经可以正常访问. 对于互联网公司来说,一旦宕机就会措手不及,如何才能 ...

  2. 太受不了了,,REST_FRAMEWORK太方便啦~~

    按英文原始的DOCUMENT走一圈,从最手工的输出到高度的集成. 最后真的就几行代码,实现最常用的JSON API..纯RESTFUL风格. 但,其核心是要记住序列化生反序列的过程,都是要以PYTHO ...

  3. 6,render的一些概念和可用库

    一,概念解释 什么是渲染?这是高大上的说法,翻译成正常语言,就是把图像缓冲区的数据显示到屏幕的过程,就是渲染. 原理说白了很简单,但实际操作中有太多因素需要考量. OS/硬件提供的加速机制/解码后图像 ...

  4. php拓展ssh功能

    1.下载拓展ssh需要的两个软件包,libssh2和ssh2. libssh2下载地址:http://pan.baidu.com/s/1hq7XOhu libssh2官网下载地址:http://www ...

  5. redis+PHP实现的一个优先级去重队列

    主要思路是用一个set做前端去重缓冲, 若干个list做后端的多优先级消息队列, 用一个进程来进行分发, 即从set中分发消息到队列. set缓冲的设计为当天有效, 所以有个零点问题,有可能在零点前s ...

  6. 解读30个提高Web程序执行效率的好经验

    其实微博是个好东西,关注一些技术博主之后,你不用再逛好多论坛了,因为一些很好的文章微博会告诉你,最近看到酷勤网推荐的一篇文章<30个提高Web程序执行效率的好经验>,文章写得不错,提到一些 ...

  7. Apache Struts 远程代码执行漏洞(CVE-2013-4316)

    漏洞版本: Apache Group Struts < 2.3.15.2 漏洞描述: BUGTRAQ ID: 62587 CVE(CAN) ID: CVE-2013-4316 Struts2 是 ...

  8. cocos2d-x 使用UIWebView加载网页(顺便可以看到如何用OC调C++)

    猴子原创,欢迎转载.转载请注明: 转载自Cocos2D开发网–Cocos2Dev.com,谢谢! 原文地址: http://www.cocos2dev.com/?p=248 前段时间项目中要微博授权登 ...

  9. 【转】 viewpage禁止滑动--android

    原文网址:http://blog.csdn.net/weiyage/article/details/8175108 最近写一个项目,涉及到viewpager,而变态的客户要求不滑动. 方法很简单 重写 ...

  10. POJ -- 2002

    #include<iostream> #include<cstdio> #include<cstring> #include<string> #incl ...