iOS的库依赖管理工具CocoaPods

原文 : 与佳期的个人博客(gonghonglou.com)

工欲善其事,必先利其器!在iOS开发中 CocoaPods 作为库依赖管理工具就是一把利器。

有了CocoaPods你再也不需要手动将需要的第三方库拖进你的工程、添加第三方库所依赖的framework、设置如-fno-objc-arc等编译参数、手动管理这些库的更新,当某个第三方库有依赖其他的库还要继续拖、拖、拖......

我们只需要将所需要的第三方库声明到一个名为Podfile文件中,然后执行Pod install命令就OK了,CocoaPods就会自动去下载我们所需要库,并为我的工程设置好相应的系统依赖和编译参数。

只能说,好用到哭~

安装CocoaPods

CocoaPods依赖于Ruby环境,刚好Mac下自带Ruby,使用Ruby的gem命令即可安装CocoaPods。
为防止因gem太老而引发问题,建议执行如下命令先更新gem:

$ sudo gem update --system

执行如下命令安装CocoaPods:

$ sudo gem install cocoapods

如果执行上述命令后没有反应,那是因为Ruby的软件源 https://rubygems.org 使用的是亚马逊的云服务而被墙了(GFW的伟大。。。)
可以用淘宝的Ruby镜像来访问cocoapods,依次执行如下命令将官方的Ruby源替换成国内淘宝的源

# $ gem sources --remove https://rubygems.org/
# $ gem sources -a https://ruby.taobao.org/

执行如下命令验证Ruby镜像的确是taobao的:

# $ gem sources -l

出现如下文字才说明上面的命令是执行成功的:

# *** CURRENT SOURCES ***
#
# https://ruby.taobao.org/

此时,再次执行gem命令安装CocoaPods:

$ sudo gem install cocoapods
$ pod setup

稍等片刻 即可安装成功。

注: pod setup 是Cocoapods将它的信息下载到 ~/.cocoapods/repos 目录下。即使在安装时不执行此命令,在初次执行 pod install 命令时,系统也会自动执行 pod setup

------10.27更新 以下------------------------------------------------

ruby.taobao.org 停止更新了,使用 cocoapods 的同学,请更新到 ruby china 的源。更新方法:
使用如下命令查看镜像源:

$ gem sources -l

更改镜像源:

$ gem sources --add https://gems.ruby-china.org/ --remove https://rubygems.org/
or
$ gem sources --add https://gems.ruby-china.org/ --remove https://ruby.taobao.org/

------10.27更新 以上------------------------------------------------

升级CocoaPods

升级CocoaPods非常简单,使用Ruby的gem命令:

$ sudo gem update cocoapods           // 更新至最新版
or
$ sudo gem update cocoapods --pre     // 更新至预览版

当然执行如下命令也可以更新:

$ sudo gem install cocoapods           // 更新至最新版
or
$ sudo gem install cocoapods --pre     // 更新至预览版

注:OS X 10.11之后升级CocoaPods会有问题。解决方案参见下一篇博客:解决OS X 10.11之后CocoaPods的升级问题

降级CocoaPods

有时我们需要降低CocoaPods版本来解决某些第三方库的兼容问题,例如RestKit不兼容CocoaPods的0.39.0版本,降级到0.38.2就OK了。

移除RubyGems中的Cocoapods程序包

查看gems中本地程序包,执行如下命令:

$ gem list

输出如下:

*** LOCAL GEMS ***

activesupport (4.2.5.2)    
bigdecimal (1.2.8)    
claide (1.0.0.beta.1, 0.9.1)    
cocoapods (1.0.0.beta.4, 0.39.0)    
cocoapods-core (1.0.0.beta.4, 0.39.0)    
cocoapods-deintegrate (1.0.0.beta.1)    
cocoapods-downloader (1.0.0.beta.1, 0.9.3)    
cocoapods-plugins (1.0.0.beta.1, 0.4.2)    
cocoapods-search (1.0.0.beta.1, 0.1.0)    
cocoapods-stats (1.0.0.beta.3, 0.6.2)    
cocoapods-trunk (1.0.0.beta.2, 0.6.4)    
cocoapods-try (1.0.0.beta.2, 0.5.1)    
colored (1.2)    
did_you_mean (1.0.0)    
escape (0.0.4)    
fourflusher (0.3.0)    
fuzzy_match (2.0.4)    
i18n (0.7.0)    
io-console (0.4.5)    
json (1.8.3)    
minitest (5.8.3)    
molinillo (0.4.4)    
nap (1.1.0)    
net-telnet (0.1.1)    
netrc (0.7.8)     
power_assert (0.2.6)    
psych (2.0.17)    
rake (10.4.2)    
rdoc (4.2.1)    
rubygems-update (2.6.1)    
test-unit (3.1.5)    
thread_safe (0.3.5)    
tzinfo (1.2.2)    
xcodeproj (1.0.0.beta.3, 0.28.2)        

其中包含的CocoaPods版本:

cocoapods (1.0.0.beta.4, 0.39.0)

移除指定版本cocoapods如1.0.0.beta.4,执行如下命令:

$ sudo gem uninstall cocoapods -v 1.0.0.beta.4

成功删除则输出:

Successfully uninstalled cocoapods-1.0.0.beta.4

还有一个0.39.0版本,移除程序包,执行如下命令:

$ sudo gem uninstall cocoapods -v 0.39.0

当移除最后一个版本时,询问:

Remove executables:
  pod, sandbox-pod

  in addition to the gem? [Yn]

按下回车键删除pod。查看CocoaPods组件的安装目录,执行命令$ which pod所得目录下的pod文件随即删除。

安装指定版本的Cocoapods程序包

安装指定版本的CocoaPods 如0.39.0,执行如下命令:

$ sudo gem install cocoapods -v 0.39.0

注:若不指定版本,即命令如sudo gem install cocoapods则默认安装最新版。

安装成功后,执行命令查看版本号:

$ pod --version

输出:

0.39.0

使用CocoaPods

搜索第三方库

为判断某第三方库(如AFNetworking)是否支持CocoaPods,执行如下命令来搜索:

$ pod search AFNetworking

若如下图所示,则可用CocoaPods管理AFNetworking


searchAFNetworking

创建Podfile的文件

CocoaPods就可以根据Podfile文件里的内容来帮你下载你所需要的库。点击前往CocoaPods官方对Podfile文件的介绍。
终端cd到你的项目所在目录下,创建Podfile文件:

$ vim Podfile

按下i键进入输入状态,在Podfile文件里输入以下文字:

platform :ios, '8.0'
    
target 'Your_App_Name' do
pod 'AFNetworking', '~> 3.0'
end

按下esc键退出输入。然后保存退出,命令是:wq。你当然可以使用vim之外的编辑软件来编辑Podfile文件。

注:cocoapods-1.0.0.beta版本后规定Podfile文件必须如上所示格式(加上target

当然,采用创建Podfile文件的另一种方式,终端cd到你的项目所在目录下执行命令 pod init 会自动生成格式,自己试一下你会喜欢的~

终端cd到你的项目所在目录下执行如下命令来利用CocoPods下载第三方库:

$ pod install

如下图所示则下载成功:

pod install

提示:[!] Please close any current Xcode sessions and use Your_App_Name.xcworkspace for this project from now on.

打开Your_App_Name.xcworkspace 工程之后会看到 Pods 文件,AFNetwoking已经成功导入项目了。

你或许应当点击前往CocoaPods官网查看对pod install vs. pod update的介绍。

注:当你 clone 别人的项目到本地后也需要终端cd到项目所在目录下执行命令 $ pod install

关于Podfile.lock的文件

执行pod install之后,CocoaPods会生成一个名为Podfile.lock的文件。并锁定当前各依赖库的版本,之后如果多次执行pod install或者团队中的其它人check下来这份包含Podfile.lock文件的工程后再执行pod install命令时,获取下来的Pods依赖库的版本就和最开始用户获取到的版本一致。如果没有Podfile.lock文件,执行pod install命令会获取第三方库的最新版本,这就有可能造成同一个团队使用的依赖库版本不一致,这对团队协作的危害无疑是灾难性的!
在这种情况下,如果团队想使用当前最新版本的依赖库,有两种方案可修改Podfile.lock的纪录:

  • 更改Podfile中各依赖库的版本
  • 执行pod update命令

鉴于Podfile.lock文件对团队协作如此重要,我们应该将它添加到版本控制里。

点击前往CocoaPods官网查看对Podfile.lock的介绍。

补充:有时执行pod update命令会特别慢,可以尝试使用如下命令:
$ pod update --verbose --no-repo-update
pod install命令同理:
$ pod install --verbose --no-repo-update

发布自己的开源框架到CocoaPods

你需要如下图创建一个Framework来打造你自己的开源框架


Framework

在工程目录下添加一份开源协议文件,一般为“LICENSE”,在 github 上新建仓库时可以同时新建 README.md 文件及 LICENSE 文件。

在开始之前你应当使用邮箱账号注册 CocoaPods

$ pod trunk register my_name@example.com 'my_name' --description='macbook pro'

随后会收到一份验证邮件,点击链接进行验证,之后通过以下命令查看注册结果:

$ pod trunk me

结果应为:

  - Name:     my_name
  - Email:    my_name@example.com
  - Since:    August 28th, 05:45
  - Pods:
    - my_framework_name
  - Sessions:
    - August 28th, 05:45 - January 3rd, 2018 10:00. IP: 116.226.129.252
    Description: macbook pro

加下来就是正式开始推送自己的框架到 CocoaPods,
发布自己的开源框架到CocoaPods同样需要一个类似Podfile的文件来告诉CocoaPods我们开源库的名称、版本、作者、描述、地址、所需的framework、依赖库等,这个文件叫my_framework_name.podspec,开始创建这个文件

终端cd到工程目录下,执行如下命令:

$ pod spec create my_framework_name

这样在你的工程目录下会生成一个my_framework_name.podspec文件,大概内容为(将对应名称修改为你自己的):

Pod::Spec.new do |s|
  s.name         = "DJLSplitCollectionView"
  s.summary      = "It is my first framework."
  s.version      = "0.0.1"
  s.license      = { :type => 'MIT', :file => 'LICENSE' }
  s.author       = { "gonghonglou" => "gonghonglou@gmail.com" }
  s.social_media_url = 'http://gonghonglou.com'
  s.homepage     = "https://github.com/gonghonglou/DJLSplitCollectionView"
  s.platform     = :ios, '8.0'
  s.ios.deployment_target = '8.0'
  s.source       = { :git => "https://github.com/gonghonglou/DJLSplitCollectionView.git", :tag => s.version.to_s }
  
  s.requires_arc = true
  s.source_files = 'DJLSplitCollectionView/*.{h,m}'
  s.public_header_files = 'DJLSplitCollectionView/*.{h}'

  s.framework  = "UIKit"

end

然后执行如下命令

$ git tag 0.0.1 // 给框架打上 tag
$ git push origin --tags    // 将 tag 推送到 github

检查 podspec 语法和项目是否正常编译,执行如下命令:

$ pod spec lint my_framework_name.podspec

确保没有任何 error 和 warning ,然后推送 podspec 到 CocoaPods 的主仓库就可以了

$ pod trunk push my_framework_name.podspec    // 提交到 CocoaPods 中心仓库

成功后结果应该为:

Updating spec repo `master`
Validating podspec
 -> DJLSplitCollectionView (0.0.1)

Updating spec repo `master`

--------------------------------------------------------------------------------
 🎉  Congrats

 🚀  DJLSplitCollectionView (0.0.1) successfully published
 📅  August 28th, 09:39
 🌎  https://cocoapods.org/pods/DJLSplitCollectionView
 👍  Tell your friends!
--------------------------------------------------------------------------------

如图:

cocoapods_push-1.png

大功告成,几秒或者几分钟后 pod search my_framework_name 搜索一下吧~
如果搜不到的话,建议执行如下方法:

rm ~/Library/Caches/CocoaPods/search_index.json
pod search my_framework_name

后记

参考链接

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 160,108评论 4 364
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,699评论 1 296
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 109,812评论 0 244
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,236评论 0 213
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,583评论 3 288
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,739评论 1 222
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,957评论 2 315
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,704评论 0 204
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,447评论 1 246
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,643评论 2 249
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,133评论 1 261
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,486评论 3 256
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,151评论 3 238
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,108评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,889评论 0 197
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,782评论 2 277
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,681评论 2 272

推荐阅读更多精彩内容