iOS目前主流的第三方管理工具是Cocoapods和Carthage,之前项目都是使用Cocoapods,虽然使用方法简单方便,但是也具有一定的弊端,侵入型太强,直接修改了我们工程的结构和配置,整个工程的文件结构被弄的很凌乱。Carthage作为一个轻量级的工具,他的好处就是不会对你的工程结构做任何的修改,没有侵入性。

    Carthage的工作原理是从Cartfile描述文件中读取第三方框架的网络地址并下载,然后通过Xcode编译成framework动态库,我们使用的时候直接导入动态库就好了,很简单。Carthage同时也是最近大热的去中心化思想的产物,第三方库不再需要上传到Cocoapods这种中心服务器统一管理,你放在任何一个可以拉取的Git都可以,不存在一台服务器宕机就影响到全部人的问题。

    优点总结如下:1.去中心化;2.无侵入型;3.可以跟CocoaPods共存(对的,你没听错,一个工程里可以同时存在Carthage和CocoaPods);4.第三方框架预先编译过了,项目编译时不会重复编译,速度比CocoaPods快。

    缺点:1.使用动态库,所以只支持iOS8+;2.支持的框架数量比Cocoapods少;3.项目中崩溃等无法在动态库中定位到源码(成熟的第三方一般不会有问题,这个不用太过考虑);4.安装包会比用Cocoapds的大。

下面我们来谈谈使用Carthage的第一步,安装Carthage。

推荐使用Homebrew来安装,如果你的电脑没有Homebrew,可以在终端使用如下指令安装:

$ /usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"

对的,这里明显看出Homebrew是基于ruby的,这一句之后,我们等执行完就安装好Homebrew了。直接安装的是最新版本,如果你的电脑之前就有Homebrew但是很久没用了,请先更新一下brew的版本,否则安装上的不会是最新版的Carthage,brew的更新也很简单,终端执行brew命令:

brew update

这里不要和brew upgrade搞混了,uograde是更新brew安装的软件的版本。brew也更新好了,那我们来安装Carthage

brew install carthage

等执行完就好了,到此我们的安装工作已经完成了。

下面我们来谈谈如何使用Carthage安装第三方:

我们先来看一下Carthage的所有指令:

Available commands:

   archive           Archives built frameworks into a zip that Carthage can use
   bootstrap         Check out and build the project's dependencies
   build             Build the project's dependencies
   checkout          Check out the project's dependencies
   copy-frameworks   In a Run Script build phase, copies each framework specified by a SCRIPT_INPUT_FILE environment variable into the built app bundle
   fetch             Clones or fetches a Git repository ahead of time
   help              Display general or command-specific help
   outdated          Check for compatible updates to the project's dependencies
   update            Update and rebuild the project's dependencies
   version           Display the current version of Carthage

旁边都有英文的解释,我就挑几个常用的说一下:

  • build 这个是吧第三方编译成动态库
  • fetch 从Git上拉取第三方
  • checkout 把描述文件中的第三方检出到工程根目录的文件夹下
  • update 这个最常用,更新现有的库并且重新编译,一步到位

我们来演示一下操作步骤:

1. 在项目根目录创建Cartfile描述文件

在终端使用cd命令进入工程根目录,然后使用touch命令新建一个文件名为Cartfile的文件

cd ~/路径/项目文件夹
touch Cartfile

2. 编辑描述文件

直接双击打开文件,在文件中写入我们要用的第三方地址和版本,关于这个Carthage要用到的版本,可以直接在这些第三方库的Git主页上找到,这里我们以Alamofire为例,可以直接在他的GitHub主页找到相应的Carthage需要的地址:

ios 如果封装第三方支付 iphone第三方_ci

复制这个写到cartfile里就好了,每加一条新的就换一行,不用打分号

ios 如果封装第三方支付 iphone第三方_动态库_02

关于版本控制,类似Cocoapods:

  • 什么都不写,默认最新版
  • == 1.0 指定版本
  • ~> 1.0 大于等于1.0,低于2.0(下一个大版本)
  • >= 1.0 最低版本是1.0

3. 执行carthage命令,编译成framework

还是在根目录之下,编辑好cartfile并保存之后,执行carthage update命令

carthage update --platform iOS

等待执行完毕,我们看以看到Carthage的整个步骤也是Fetching -> Cloning -> Checking out -> Building scheme,这些步骤,都可以在上面的命令里找到对应的命令。

--platform iOS 这句是可选的,指定要编译的系统,因为有的第三方框架可以在macOS、wathcOS、tvOS、iOS等多个平台使用,不指定的话,默认会编译全部支持的系统。

ios 如果封装第三方支付 iphone第三方_ios 如果封装第三方支付_03

执行完成之后,我们可以在工程根目录看到多了一些东西

ios 如果封装第三方支付 iphone第三方_ios 如果封装第三方支付_04

Cartfile.resolved里记录的是当前第三方库的版本号,Carthage文件夹中就是拉取下来的源码和编译得到的动态库。

4. 工程中使用动态库

TARGETS -> Build Phases -> Linked Binary With Libraries中点击加号,然后选择Add Other,在Carthage/Build/iOS目录下选中你要的.framework文件

ios 如果封装第三方支付 iphone第三方_iOS_05

然后在下面的Run Script中新增一条脚本命令

/usr/local/bin/carthage copy-frameworks

这里是调用Carthage的指令复制这些动态库到工程,在input files里添加都应的路径,我们就大功告成啦。

ios 如果封装第三方支付 iphone第三方_ios 如果封装第三方支付_06

至此配置就完成了,在代码中需要使用第三方的地方,import引用对应的头文件就可以了。