cocoapods安装和使用

场景一:cocoapods安装步骤

配置 cocoapods需要 ruby, 更新 ruby 需要 rbenv, 下载 rbenv 就需要 homebrew, 所以安装顺序就是 homebrew -> rbenv -> 更新ruby -> cocoapods

安装 Xcode

Xcode:CocoaPods是用于iOS开发的依赖管理工具,因此你需要先安装Xcode。

安装Homebrew

Homebrew:Homebrew是一款Mac OS平台下的软件包管理工具,拥有安装、卸载、更新、查看、搜索等很多实用的功能。它简化了安装和管理软件的过程。

    // 安装Homebrew
    /bin/bash -c "\$(curl -fsSL <https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh>)"

    //验证是否安装brew成功
    brew -v
    
    //更新 Homebrew
    brew update

安装Ruby

Ruby:CocoaPods是用Ruby编写的,因此你需要安装Ruby。虽然macOS自带了Ruby,但你可能需要更新到较新的版本。你可以使用Homebrew来安装或更新Ruby。

brew search ruby   #来查看所有可用的Ruby版本。
brew install ruby@NEW_VERSION  # 替换NEW_VERSION为你想要安装的具体版本号

安装 rbenv(或者rvm)

rbenv(可选):rbenv和rvm都是 Ruby 版本管理器,允许开发者在同一台机器上轻松安装、切换和管理多个 Ruby 版本。

brew install rbenv  # 安装rbenv

将rbenv初始化脚本添加到你的shell配置文件中

echo 'if which rbenv > /dev/null; then eval "$(rbenv init -)"; fi' >> ~/.zshrc

使更改生效 & 验证rbenv

source ~/.zshrc  #使更改生效

rbenv --version   #验证rbenv

安装CocoaPods

CocoaPods:最后,当然就是安装CocoaPods本身了。在确认已经安装了Ruby之后,你可以通过运行sudo gem install cocoapods命令来安装CocoaPods。

 sudo gem install cocoapods #安装
 pod --version  # 验证

场景二、cocoapods 卸载->重装

1、如果之前装过cocoapods,最好先卸载掉,卸载命令:

$ sudo gem uninstall -n /usr/local/bin cocoapods

2、查看本地安装过的cocoapods相关东西

$ gem list --local | grep cocoapods
sudo gem install -n /usr/local/bin cocoapods

会显示如下:然后逐个删除吧:

cocoapods-core (0.39.0)

cocoapods-downloader (0.9.3)

cocoapods-plugins (0.4.2)

cocoapods-search (0.1.0)

cocoapods-stats (0.6.2)

cocoapods-trunk (0.6.4)

cocoapods-try (0.5.1)
$ sudo gem uninstall -n /usr/local/bin cocoapods-core

二、安装

1、 查看下当前ruby版本,如果用这个版本接下来工作失败了,就更新下ruby

 ruby -v

2、更换cocoapods镜像:

$gem sources --remove https://rubygems.org/ 
$ gem sources --add https://gems.ruby-china.com 
$gem sources -l  (用来检查使用替换镜像位置成功)

3、下载安装CocoaPods

sudo gem install -n /usr/local/bin cocoapods

三、错误处理:

1、ERROR: Could not find a valid gem 'cocoapod' (>= 0) in any repository
说明你还没有安装命令行工具,执行下这个命令:

 Xcode-select --install 

就会发现 弹出一个窗问我们是否要安装命令行工具 。 安装完了后 再次sudo gem install cocoapods 发现还是会报同样的错误,可能是权限的问题,使用sudo -i或者sudo su进入到root之后再 执行sudo gem install -n /usr/local/bin cocoapods 。
command+q退出一下 再重新进入Shell里面 执行sudo gem install -n /usr/local/bin cocoapods 会发现出来一大段。
2、本地多个Ruby环境导致pod执行失败
如果执行任意pod指令都失败,失败信息像下面这样:

Ignoring ffi-1.13.1 because its extensions are not built. try: gem pristine ffi —version 1.13.1
Ignoring gem-wrappers-1.4.0 because its extensions are not builts. Try: gem pristine gem-wrappers —version 1.4.0
Traceback (most recent call last):
    23: from /USR/LOCAL/BIN/pod:23:in `<main>`
    22: from /USR/LOCAL/BIN/pod:23:in `load`
    21: from /Users/username/.rvm/rubies/ruby-2.6.0/lib/ruby/gems/2.6.0/gems/cocoapods-1.9.3/bin/pod:36:in `<top (required)>`
    20: from /System/Library/Frameworks/Ruby.frameworks/Versions/2.6/usr/lib/ruby/2.6.0/rubygems/core_ext/kernel_require.rb:54:in `require`

如果是这样子的话,根据错误提示说明是本地有多个Ruby环境导致的,看看根目录下是否多了 rvm 目录,或者.rvm目录下多了个Ruby,删除多余的rvm目录或目录下的Ruby即可。

四、下载指定pod的版本

//Analyzing dependencies
[!] The version of CocoaPods used to generate the lockfile (1.9.2) is higher than the version of the current executable (1.9.1). Incompatibility issues may arise.
Downloading dependencies
/
同事的pod版本不一致,git就会一直提示到有这个修改,很烦人。

查看当前pod版本:

pod --version

直接下载想要的pod版本:

sudo gem install cocoapods --version 1.9.1

删除不想要的版本:

sudo gem uninstall cocoapods
Select gem to uninstall:
 1. cocoapods-1.9.1
 2. cocoapods-1.9.2
 3. All versions
> 2
//Successfully uninstalled cocoapods-1.2.1

再次查看当前pod版本:执行一次当前pod的install命令

pod --version
pod install

五、 spec资源所有库的配置信息

  • 在cocoapods安装完成以后,在用户根目录下有个隐藏文件夹,/Users/<user>/.cocoapods.

    image
  • /Users/<user>/.cocoapods/repos/master/Specs/里面是cocoapods收录的所有库的配置信息.Specs目录下,并不是直接是以库的名称命名的文件夹,而是分了3层目录,分别以0-f来命名,比如SDWebImage的配置文件位置就是/Users/<user>/.cocoapods/repos/master/Specs/1/1/7/SDWebImage

    image
  • 这里为什么会分为三层目录,是根据什么划分的呢?其实这里是把某个库的名称做了md5,md5前三位是其所对应的三层目录,比如SDWebImage的md5是1173B6117A2CF4A6756F761AEDAE9D2C,那么其目录结构就是1/1/7.

  • Spec内的框架每一个版本内并不是具体的代码,而是一个json文件,里面记录这该框架当前选中的版本的详细信息,包括作者、github位置....等等.

    image

六、podfile文件 ——关于版本指定约束

  • 一般我们在使用cocoapods导入第三方库前都会生成一个podfile文件,文件中记录着我们要导入的第三方库以及对应的版本信息,比如:

pod 'SDWebImage', '~> 4.3.2'
这里的意思是指:让cocoapods导入SDWbImage框架,版本号4.3.2和版本号处于4.3.2-4.4之间的,不包括4.4和更高版本.

所以要想cocoapods导入的框架是我们想要的,必须了解一下版本制定的约束

  • pod ‘ SDWebImage’ --- 不指定版本,表示希望使用最新版本
  • pod 'SDWebImage', '4.3.2' --- 指定明确版本,表示只想要这个版本
  • 逻辑关系
    '> 0.1' --- 版本号大于0.1的
    ‘>= 0.1’ --- 版本0.1和版本号大于0.1的
    '< 0.1' --- 版本号小于0.1的
    ‘<= 0.1' --- 版本号0.1和版本号小于0.1的
  • 最优匹配
    ‘~> 0.1.2' --- 版本0.1.2和版本号处于0.1.2-0.2之间的,不包括0.2和更高版本
    ‘~> 0.1' --- 版本0.1和版本号处于0.1-1.0之间的,不包括1.0和更高版本
    ‘~> 0' --- 版本0和更高,和没设没啥区别

七、常用命令 pod install、pod update、.pod repo update 、 pod install --no-repo-update

pod install:执行该命令时,如果Podfile.lock文件存在, 则直接从此文件中读取框架信息并且它会只下载Podfile.lock文件中指定的版本安装。对于不在Podfile.lock文件中的pod库,pod install命令会搜索这个pod库在Podfile文件中指定的版本来安装,安装完毕更新Podfile.lock文件
如果Podfile.lock不存在, 则会读取Podfile文件内的框架信息,然后执行下载并且根据下载好的框架信息, 生成Podfile.lock文件.

pod update:只有当你想要更新pod库的版本时才使用pod update;它不管Podfile.lock是否存在, 都会读取Podfile文件的的框架信息去下载安装,下载好之后, 再根据下载好的框架信息, 生成Podfile.lock文件.

pod repo update: 更新整个.cocoapods下的所有库的配置文件,挨个检查对应的框架有没有新版本发布,有的话更新本地的资源配置文件.

--no-repo-update:跳过检查框架有没有新版本发布的环节,一般配合pod install使用.
pod install --no-repo-update:根据podfile文件或者podfile.lock下载并导入对应的第三方库,跳过检查资源配置文件是否需要更新的环节.

八、 pod 常用命令

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

推荐阅读更多精彩内容