一、什么是CocoaPods?
前言: 思考如何引入一个第三方框架。 例如: 百度地图SDK、友盟、ShareSDK、 信鸽推送等。
从github或某处下载第三方SDK
工程中导入所需要的SDK的文件 .a 或 .framework
添加SDK文件所依赖的系统的.framework。比如:
需要导入SystemConfiguration.framework、CoreLocation.framework、UIKit.framework、libsqlite3. dylib(Xcode 7.0下是tbd文件)等很多系统库。
有可能还需修改-ObjC、修改Objective-C++
如果SDK更新了, 我们还需要把这个SDK移除掉, 再拖入一次
正如上所述,大家如果要使用第三方的SDK,需要重复以上的步骤。如此麻烦又浪费时间, 并且都是重复性的操作,并没有任何营养。因此, 如果想避免上述重复性的操作就可以使用CocoaPods这个工具。
CocoaPods 是一个第三方库依赖管理工具。使用一行终端命令即可达到引入第三方库的目的。CocoaPods的使用方式非常简单。
二、CocoaPods安装前准备
CocoaPods使用Ruby语言编写而成。因此需要Ruby的环境, 庆幸的是OS X已经集成了Ruby环境。我们所需要的做的就是通过gem去安装CocoaPods即可。
首次安装CocoaPods之前,Ruby默认源在墙外, 因此我们需要修改下Ruby默认使用的源:
1.查询Ruby的源
gem source -l
查询结果如下:
*** CURRENT SOURCES ***
https://rubygems.org/
查到的这个源是在墙外, 并且淘宝为我们提供了对应的源链接,因此我们需要先移除源链接, 再添加淘宝的源:
2.移除Ruby的源
gem source --removehttps://rubygems.org/
移除结果如下:
http://rubygems.org/removed from sources
3.添加Ruby的源(最近做了修改, 改为了https)
gem source -ahttps://ruby.taobao.org/
添加结果如下:
https://ruby.taobao.org/added to sources
对源的操作完成后, 就可以安装CocoaPods了。
三、CocoaPods安装
3.1.终端运行以下命令, 即可实现CocoaPods的安装
sudo gem install cocoapods
运行之后需要输入电脑的密码, 并且没有密码输入的位数提醒。输完密码就进行安装了,安装过程可能会很慢,耐心等待。
3.2.上述命令安装完成后,输入以下命令, 进行Cocoapods的建立,耐心等待,时间会很长
pod setup
如果上述命令运行, 皆无错误即完成了CocoaPods的安装!To update use: `sudo gem install cocoapods --pre`
3.3.如果终端gem太老,可以尝试用如下命令升级gem
sudo gem update --system
CocoaPods安装过程中可能遇到的问题
xcrun找不到Xcode
xcrun: error: active developer path
("/Applications/Xcode.app/Contents/Developer/") does not exist, use \xcode-select --switch path/to/Xcode.app\to specify the Xcode that you wish to use for command line developer tools (or see \man xcode-select\)
运行以下命令, 让xcrun的运行路径找到对应的Xcode
sudo xcode-select -switch /Applications/Xcode.app/Contents/Developer
四、CocoaPods的使用
1. 创建一个需要使用CocoaPods的工程, 并在工程目录下创建Podfile文件
终端输入一下命令后,回车:
cd /Users/apple/Desktop/KVODemo 注意cd 跟/Users/apple/Desktop/KVODemo中间的空格一定要有
终端再输入以下命令,回车:
pod init (或者执行$touch Podfile命令)
创建完成如下图中, 会出现Podfile文件
创建完Podfile
2.编辑Podfile文件
2.1. 编辑Podfile文件前,先打开终端,执行命令cd /Users/apple/Desktop/KVODemo确定下操作的到底是哪个工程项目(KVODemo)。
2.2. 再执行命令ls查看该项目中的文件:
2.3. 向Podfile文件里面添加第三方类库前,做一个安全处理,确定项目中是否存在Podfile文件,如果不存在,在终端中执行以下命令,创建一个Podfile文件:
3.pod搜索功能
3.1.CocoaPods上的大部分第三方框架均来自于GitHub, 因此数量也很庞大,记名字是很不明智的,因此,我们可以选择通过搜索来找到自己想要寻找的第三方框架。
pod search 框架关键字, 如下:
pod search sdweb
pod search afmetworking
通过搜索命令, 搜索到的内容如下图:
3.2.搜索结果如下图
3.3.然后把你想要的框架的名字, 复制到Podfile文件中即可,Podfile文件中的第三方可以有多个, 需要几个,就填入几个,CocoaPods 会全部帮你下载下来。(可以在终端输入命令:bogon:KVODemo apple$ open -e Podfile 来打开Podfile文件)
4.执行第三方的下载安装(afnetworking)
复制保存上面的AFNetworking后,再执行以下命令即可
同样也是要在工程目录下
执行以下命令:
pod install
等其执行完毕,即可完成第三方库的安装
其中还可以调用pod update方法, 也可以达到第三方库安装的目的, 并且会更新版本
在pod install或者pod update过程中会执行podspec索引的更新,需要等待很久,因此为了提升速度可以执行如下命令, 关掉索引的更新
pod install --no-repo-update
并且在安装过程中, 我们不知道cocoapods做了什么, 还可以添加一个参数,用来提示我们,cococapods做了哪些操作
pod install --verbose --no-repo-update
安装完成后, 工程目录下会多出一个白色的文件,如下图:
通过CocoaPods安装完第三方后
之后再打开工程,就用白色的工程文件打开,不再使用蓝色的工程文件。
打开之后,工程的目录层级如下图:
打开工程后
其中Pods工程目录是用来存放第三方库和配置文件的,上面的CocoaPods依旧是我们的工程文件, 在它之中,我们可以继续正常的编写代码。
为了验证是否安装成功, 我们可以在AppDelegate.m中引入我们所要使用的第三方库的头文件,如引入AFNetworking
#import
这里需要注意的是, 以后再引入第三方框架,要当系统框架去引入用\#import <框架头文件.h>
至此, 就完成了CocoaPods的创建和使用。
五 、删除cocoapods
1.删除工程文件夹下的Podfile、Podfile.lock和Pods文件夹。
2.删除xcworkspace文件。
3.打开xcodeproj文件,删除项目中的libpods.a和Pods.xcconfig引用:
4.打开Build Phases选项,删除Check Pods Manifest.lock和Copy Pods Resources:
完成,编译运行,无错通过。