iOS Cocoapod 集成

CocoaPods简介:

CocoaPods是iOS项目的依赖管理工具,该项目源码在Github上管理。开发iOS项目不可避免地要使用第三方开源库,CocoaPods的出现使得我们可以节省设置和第三方开源库的时间。 在使用CocoaPods之前,开发项目需要用到第三方开源库的时候,我们需要

1.把开源库的源代码复制到项目中
2.添加一些依赖框架和动态库
3.设置-ObjC,-fno-objc-arc等参数
4.管理他们的更新

在使用CocoaPods后,我们只需要把用到的开源库放到一个名为Podfile的文件中,然后执行pod install.Cocoapods就会自动将这些第三方开源库的源码下载下来,并且为我们的工程设置好响应的系统依赖和编译参数。

一、CocoaPods的原理

CocoaPods的原理是将所有的依赖库都放到另一个名为Pods的项目中,然后让主项目依赖Pods项目,这样,源码管理工作都从主项目移到了Pods项目中。Pods项目最终会编译成一个名为libPods.a的文件,主项目只需要依赖这个.a文件即可。

二、Cocoapod的安装:

1、ruby环境:

在安装Cocoapod前要确认ruby是否正确安装,可以用如下命令确认当前ruby环境:
  $ ruby -v
下面是我的的ruby环境:
ruby 2.3.7p456 (2018-03-28 revision 63024)

屏幕快照 2019-01-30 上午10.42.56.png

2、添加gem源

淘宝源:https://ruby.taobao.org/
China源最新域名:https://gems.ruby-china.com
淘宝源已经停止维护了,现由 ruby-china 提供镜像服务,可以使用China源作为gem源。

首先需要确认自己的gem源:

  1. 查看是否添加了gem源:
      $ gem sources -l
      https://gems.ruby-china.org/
    如果添加了淘宝的源,可以使用如下命令修改gem源:
    $ sudo gem sources --add https://gems.ruby-china.org/ --remove https://ruby.taobao.org/
    ruby-china的域名已经更新为.com,可以更新一下源:
    $ sudo gem sources --add https://gems.ruby-china.com/ --remove https://gems.ruby-china.org/
屏幕快照 2019-01-30 上午11.22.00.png
  1. 如果没有添加gem源,可以使用如下命令添加gem源:
      $ sudo gem sources --add https://gems.ruby-china.com
      添加完成后,确认当前gem源:
      $ gem sources -l
      https://gems.ruby-china.com

  2. 查看gem源版本:
      $ gem -v
      2.5.2.3

屏幕快照 2019-01-30 上午10.55.50.png
3、安装Cocoa-pod
  • gem 安装 cocoapods
    $ sudo gem install cocoapods --pre
    $ sudo gem install cocoapods -v 1.4.0
屏幕快照 2019-01-30 上午11.27.36.png
  • pod setup

此过程很是缓慢
  $ pod setup
  Setting up CocoaPods master repo

屏幕快照 2019-01-30 下午12.02.37.png

三、使用Cocoapod为工程导入第三方库

1、为主工程生成Podfile
在工程的.xcodeproj目录(必须在此目录)中,执行如下命令,即可得到Podfile。
  $ pod init
2、编辑Podfile文件

# Uncomment the next line to define a global platform for your project
# platform :ios, '9.0'

target 'POD_DEMO' do
# ~> 后面的数字是 3.2 版本,可以省略,则安装或升级最新版本
pod 'AFNetworking','~>3.2'

end

3、生成.xcworkspace工程入口

按照上面的步骤,在子工程下面添加完成podspec之后,在主工程的Podfile对应目录下执行如下命令,即可得到对应的 *.xcworkspace工程入口。
  $ pod install --no-repo-update

4、运行.xcworkspace启动工程,可以看到工程已经添加了pod

四、常用的Pod命令:

# 创建 Podfile 文件
  pod init

# 下载“Podfile”中定义的所有依赖项,并创建一个pod库
  pod install

# 下载“Podfile”中定义的所有依赖项,并创建一个pod库,不更新本地代码库
  pod install --no-repo-update 

# 更新Podfile中依赖的框架
  pod update

# 更新Podfile中依赖的框架,可以安装新框架或者删除不用的框架,但是不会升级项目已经安装的框架
  pod update --no-repo-update 

# 查看哪些框架有更新版本
 pod outdated

# 搜索框架 #空格 下一页 #q 退出
  pod search AFNetworking

# 只搜索符合名字的框架
  pod search AFNetworking --simple

# 帮助命令
  pod --help

#其他命令的用法可以用 命令+ --help的方式查看用法帮助

五、从工程中删除Cocoapod:

删除工程中的Cocoapod需要删除下列文件:

  1. 删除工程文件夹下的Podfile、Podfile.lock及Pods文件夹
  2. 删除xcworkspace文件
  3. 使用.xcodeproj文件打开工程,删除Frameworks组下的libPods.a引用以及Pods.xcconfig,以及残留的pod文件夹。
  4. 删除工程pod配置项 TARGET->Build Phases ->

[CP] Check Pods Manifest.lock
[CP] Copy Pods Resources
[CP] Embed Pods Frameworks

屏幕快照 2019-01-30 下午3.45.14.png

五、制作自己的Cocoapod库

pod网站: https://cocoapods.org

制作私有库的基本步骤:

1.在github创建一个共有库
2.clone到本地,在该文件夹内创建一个新的项目
3.上传到github上
4.创建或登录trunk账号
5.添加.podspec文件
6.podspec上传到github
7.添加库tag标记
8.验证podspec文件
9.podspec上传到Cocoapod中
10.更新本地仓库
11.查看上传结果
12.更新维护自己的库

1.在github上创建一个共有库:

如图:

屏幕快照 2019-01-31 下午3.16.05.png

2.clone到本地,在该文件夹内创建一个新的项目:

新建的项目一般会自带一层目录,可以将此目录去掉,将准备公开的库文件放在一个文件夹中,同LICENSE,README文件放在同一目录下:
结果如图:


屏幕快照 2019-01-31 下午3.25.26.png

3.上传到github上

相关命令:
$ git add .
$ git commit -m "本次提交的具体内容"
$ git push

4.创建或登录trunk账号

我们要让用户使用我们的的库,就需要上传到CocoaPod网站进行托管.而要上传文件到CocoaPod,就要创建trunk账户.

4.1 检测是否已经登录
$ pod trunk me

如果没有那么创建用户
4.2 创建pod trunk 用户
pod trunk register youxiang@163.com "YourName"

4.3 查收邮件
收到邮件,点击邮件的链接,会跳转到一个页面,提示验证通过
执行:$ pod trunk me
验证一下

5.添加.podspec文件

我的代码已经提交到github上,还需要上传到CocoaPod上,.podspec文件就是帮助用户搜索到我们制作的库文件的描述文件.

创建.podspec文件有两种方法

方法一:复制已经较成熟的第三方库的.podspec文件到你的项目中,然后将各种信息改成你自己的
下面是我的.podspec

Pod::Spec.new do |s|
  s.name         = "SKImageCodeTypeTool" //库名字
  s.version      = "1.0.0" //库版本号
  s.ios.deployment_target = '6.0'
  s.summary      = "A picture encode format check" //库的简介
  s.homepage     = "https://github.com/emptyglass123/SKImageCodeTypeToolDemo" // 库的github地址
  s.license      = "MIT" // license 创建git仓库时勾选的
  s.author             = { "author" => "111111111@163.com" }// 库的作者
  s.social_media_url   = "https://github.com/emptyglass123/SKImageCodeTypeToolDemo"
  s.source       = { :git => "https://github.com/emptyglass123/SKImageCodeTypeToolDemo", :tag => s.version }
  s.source_files  = "SKImageCodeTypeTool" // 暴露给用户的库文件所在文件夹
  s.requires_arc = true // ARC 
end

方法二:手动创建,先切到工程目录,执行命令
pod spec create 库名
随后会在当前目录下生成一个库名. podspec文件,使用Xcode打开,编辑相关项:

完整文件目录结构:


屏幕快照 2019-01-31 下午4.27.51.png

6.将. podspec文件上传到github

git add .
git commit -m "添加了 .podspec文件"
git push

7.添加tag标记

git tag 1.0.0
git push --tags
这句话就是给我们的库文件打tag,这个tag一定要和.podspec文件内容一一对应,否则有问题

8.验证podspec文件

我们去验证自己的库文件的时候,这样写

pod spec lint
或者
pod spec lint SKImageCodeTypeTool.podspec

但是有的时候会有一些warning,然后就验证失败,所以我们此时可以

pod spec lint SKImageCodeTypeTool.podspec --allow-warnings
屏幕快照 2019-01-31 下午4.08.56.png

9.上传到Cocoapod:

如果刚才验证,没有发现警告,那么可以直接这个样上传
pod trunk push KImageCodeTypeTool.podspec

如果有警告,那么我们要去修改警告或者忽略警告
pod trunk push KImageCodeTypeTool.podspec --allow-warnings

上传成功!


屏幕快照 2019-01-31 下午4.12.14.png

10.更新本地库:

因为CocoaPod本身一直在集成很多开发者的库,他的master分支一直是在更新的,但是你本地的库相对于刚才上传SKImageCodeTypeTool的时间节点你本地的库是老的
所以我们要去更新一下本地的库,具体操作:

pod setup //初始化
pod repo update//更新仓库

11.查看上传结果:

pod search SKImageCodeTypeTool //查找
会有一定延迟:
pod tunk me

屏幕快照 2019-01-31 下午4.15.45.png

可以再pop网站搜索
https://cocoapods.org

12.更新维护自己的库

1.修改项目源码
2.上传github
3.修改.podspece内部的版本号
4.打tag(同.podspece中版本号)
5.上传tags

六、Cocoapod的升级:

1.查看当前ruby源路径:

gem sources -l
*** CURRENT SOURCES ***
http://gems.ruby-china.org/

2、更新一下gem版本

sudo gem update --system
直到看到
RubyGems system software updated
或者 Latest version already installed. Done.
说明gem版本更新成功

3、更新cocoapods

sudo gem install -n /usr/local/bin cocoapods --pre
更新完成之后,再次查看cocoapods的版本
pod --version

截屏2020-03-28上午11.46.19.png

参考链接
https://www.jianshu.com/p/283584683b0b
https://www.jianshu.com/p/e52bb69628a9
https://www.jianshu.com/p/43f5d099e147

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

推荐阅读更多精彩内容