美文网首页
CocoaPods入门(上)

CocoaPods入门(上)

作者: 楚丶liu香 | 来源:发表于2018-06-21 17:39 被阅读83次

CocoaPods是一个用来帮助我们管理iOS第三方依赖库的工具。在CocoaPods出现之前,我们在使用第三方库的时候通常做法是直接将第三方库源码拖入项目中直接使用或者设置成git的submodule。这种做法会有一些问题,比如一个第三方库又依赖了一些系统的或其他的framework,我们就需要手动的将这些依赖补齐,这比较麻烦并且没有什么技术含量。CocoaPods的出现解决了这些问题,我们只需要关注要引入的第三方库,然后使用Podfile文件将其引入,执行pod install,一切搞定。

文章分为上下两篇,上篇主要说下安装使用和原理,下篇是私有库的搭建和使用。

1、安装

CocoaPods是用Ruby构建的,要想使用它首先需要有Ruby的环境。可以直接使用MAC的OS X提供的默认Ruby来安装,具体的执行命令操作如下:

$ sudo gem install cocoapods
$ pod setup 
  • 执行完install命令半天没反应

Ruby的软件源是https://rubygems.org/,使用的亚马逊的云服务,由于种种原因我们是无法访问的,但是我们可以通过更换Ruby源的方式解决这个问题。之前的解决方案是使用国内淘宝的源https://ruby.taobao.org/,但是这个站点已经不再继续维护了,为了正常使用我们还是使用下边的设置吧:

$ gem sources --remove https://rubygems.org/ 
$ gem sources -a https://gems.ruby-china.com 

上边操作完成后,可以执行下边的命令查看是否替换成功。

$ gem sources -l 

正常的输出是:

*** CURRENT SOURCES ***

https://rubygems.org/
  • gem版本过老

gem是管理Ruby库和程序的标准包,如果它的版本过低也可能导致安装失败,解决方案自然是升级gem,执行下述命令即可:

$ sudo gem update --system 
  • pod setup等待时间太久

pod setup在执行时,CocoaPods会将托管在https://github.com/CocoaPods/Specs上面的所有项目的Podspec文件更新到~/.cocoapods/目录下,这个文件很大,所有第一次更新会非常慢。方法是直接手动下载到本地,操作如下:

$ git clone https://code.aliyun.com/Magi/CocoaPods.git ~/.cocoapods/repos/master --progress

2、使用

2.1 创建Podfile文件

在Xcode项目的根目录下执行命令创建Podfile文件,操作如下:

$ pod init

Podfile文件的格式如下:

source 'https://github.com/CocoaPods/Specs'  #源的下载地址

platform :ios, '7.0'                         #支持的ios系统最低版本

pod 'SDWebImage', '~> 4.3.3'                 #第三方库以及版本号

target 'XXApp' do                            #项目的target
    # use_frameworks!
end

注意:

  1. 用CocoaPods导入swift第三方库时必须要用use_frameworks!
  2. 使用use_frameworks!表示打包成.framework库使用,否则将打包成.a静态库使用。

2.2 安装依赖库

Podfile文件创建完成后,在当前的工程目录下,执行命令来安装依赖库:

$ pod install

2.3 更新依赖库

当依赖的第三方库升级新版本后,一般使用pod update命令来更新第三方库

  • 全部更新

如果要将所有依赖第三方库更新到Podfile的指定版本,需要执行命令如下:

$ pod update

在执行pod update后,会把制定的第三方库更新到x.x.x~x.(x+1).0之间的最新版本,举个例子,pod 'SDWebImage', '~> 4.3.3',要使用的是4.3.3到4.4.0之间的最新版本。如果Podfile里边是这样指定第三方库的版本号,那么每次pod update都可能会更新依赖库,对于需要保证稳定开发的App来说可能是不利的,我们可以通过直接指定版本号(pod 'SDWebImage', '4.3.3')的方式来避免这个问题。

直接执行pod update命令,首先会去更新本地.cocoapods/repos/master目录下的spec仓库,这个仓库比较大每次都更新比较费时,可以通过追加参数避免更新直接更新依赖库,命令如下:

$ pod update --no-repo-update

这种做法会存在一些问题,比如你的本地spec仓库比较老,这时更新的依赖库可能就不是GitHub上面对应第三方库的最新版本,可能一些bug的修复和新功能就没办法及时修补和使用。

  • 更新指定库

如果想只更新某个依赖库,可以在pod update后面加上库名,如下:

$ pod update [LIB_NAME]     #库的名称

2.4 查找第三方库

如果想要查找某个第三方库或者查看某个第三方库的最新版本,可以使用如下命令:

$ pod search [LIB_NAME]     #库的名称

2.5 Podfile.lock作用

在开始使用CocoaPods,执行完pod install之后,会生成一个Podfile.lock文件,每次执行pod update也会更新Podfile.lock文件。Podfile.lock文件最大的作用在于多人开发时,保证团队中每个人使用的依赖库的版本一致。

Podfile.lock是第一次pod install时生成的,Podfile.lock里面会标注当前项目依赖库的指定版本,这样在多人协同开发的时候,别人同步了你的podfile.lock文件后,他执行pod install就会安装podfile.lock中的指定版本依赖库,保证了大家使用依赖库版本的一致性,避免不一致带来的开发问题。Podfile.lock应该纳入版本控制之下。但是Podfile.lock并不是一成不变的,当修改了Podfile文件,执行pod update时,就会更新Podfile.lock文件。

pod update你会根据Podfile文件的规则更新所有依赖库,不会理睬现有的Podfile.lock,而是根据安装依赖库的情况生成新的Podfile.lock文件

3、原理

3.1 下载原理

当使用CocoaPods导入第三方库时,CocoaPods首先会根据第三方库的git地址去找到git仓库,找到后根据tag(就是pod 'SDWebImage', '~> 4.3.3'所指定的第三方库版本)去找对应版本的提交(如果没有指定版本,那么会找最后一次的提交),然后在这次提交中检索后缀为.podspec的文件。找到后首先会验证s.name是否与Podfile中指定的第三方库名是否一致,不一致则会报[!] Unable to find a specification for 'SDWebImage'.的错误。验证成功后根据s.source_files找到需要导入的源文件和相关资源文件和配置文件等,最后将其下载到本地项目中。

3.2 集成原理

CocoaPods会把所有下载到本地项目的所有第三方库通过Pods项目来进行管理,这样第三方库的管理工作通过CocoaPods转移给了Pods项目,主项目只要依赖Pods项目,所有的使用就变得一目了然。Pods项目最终会编译成一个名为libPods.a的文件,主项目只需要依赖这个文件即可。对于资源文件,CocoaPods提供了一个名为Pods-resources.sh的bash脚本,该脚本在每次项目编译的时候都会执行,将Pods依赖库的各种资源文件复制到目标文件中,还通过Pods.xcconfig文件在编译时设置所有依赖和参数。

参考

CocoaPods官方文档
用CocoaPods做iOS程序的依赖管理
CocoaPods的原理与技巧

相关文章

  • CocoaPods入门(上)

    CocoaPods是一个用来帮助我们管理iOS第三方依赖库的工具。在CocoaPods出现之前,我们在使用第三方库...

  • CocoaPods 指南

    https://guides.cocoapods.org/ 使用CocoaPods 入门 这是设置CocoaPod...

  • CocoaPods入门(下)

    上一篇文章主要是CocoaPods的安装及入门使用,以及一些注意事项,是日常工作中最常用的。CocoaPods不但...

  • CocoaPods:你想要的都在这

    CocoaPods 入门 什么是 CocoaPods CocoaPods是OS X和iOS下的一个第三类库管理工具...

  • CocoaPods学习笔记之一

    前言 看了Cocoapods系列教程了,很赞,本篇文章纯属笔记,原创地址Cocoapods系列教程(一)——入门 ...

  • CocoaPods库开发入门

    CocoaPods库开发入门 一、创建CocoaPods库模板项目,以下假如我们的库名为MyLib。 接着,Coc...

  • CocoaPods入门

    1.打开终端,使用cd命令切换到项目目录:例如:cd Exercises/TestCocoaPods2.在终端使用...

  • CocoaPods再次入门

    最近换了台新电脑,重新装了一下开发环境,踩了好多坑?,感觉有必要写下来备用 1,什么是cocoapods coco...

  • Cocoapods入门概览

    对于一个项目从生产力的角度来说,我们都不能保证自己写的每一行代码是否在某种程度上重复的造"轮子".换言之对于通用的...

  • cocoapods 使用入门

    一、简介 CocoaPods 是一应用级别的依赖管理器,针对Objective-C、Swift和其他任一在Obje...

网友评论

      本文标题:CocoaPods入门(上)

      本文链接:https://www.haomeiwen.com/subject/mhkcyftx.html