资讯专栏INFORMATION COLUMN

CocoaPods创建公有和私有Pod库方法总结

Lavender / 1793人阅读

引言

刚毕业那段时间接触到的一些文章到处都在大谈iOS工程模块化(CocoaPods化), 本人也一直在着力于将公司项目代码解耦合, 但是因为一个人开发实在没有必要将工程CocoaPods化, 所以迟迟没有去研究将工程CocoaPods化的方法, 期间本人也抽时间去参加过蘑菇街等平台举办的架构交流会, 如今公司业务发展稳定, 终于有时间将创建公有pod库将自己的代码供其他开发者pod依赖使用的方法, 以及创建本地/内网的私有Pod库供公司项目组件CocoaPods化的方法研究清楚, 把这几天整理的笔记做个记录.

创建公有Pod库或者私有Pod库, 实际上原理是一样的, 都是基于git服务和repo协议, 不一样的是, 两者的版本索引查询方式不一样, 公有库的podspec由CocoaPods/Specs管理, 而内部私有使用的pod库需要自己建立一个仓库来管理podspec.

正文目录
一. 创建公有Pod库
1、注册CocoaPods账户信息
2、创建共享库文件并上传到公有仓库
3、编辑.podspec文件
4、打tag, 发布一个release版本
5、发布自己的库描述文件podspec给cocoapods
6、关于查找和使用新创建的库
7、更新维护podspec
二. 创建私有Pod库
1、创建一个git仓库用来做内部私有库的Spec Repo
2、创建私有Pod组件库
3、然后将podspec加入私有Sepc repo中
4、查找和使用内部组件库
一. 创建公有Pod库

例子: 我的第一个公共pod库JM_ActionSheet, Podfile中添加pod "JM_ActionSheet"即可使用.

1、注册CocoaPods账户信息

想要创建一个开源pod库, 首先我们需要注册CocoaPods, 这里使用trunk方式, 作为一个iOS开发人员你一定安装了CocoaPods, 那么只需要在终端执行:

pod trunk register 邮箱地址 "用户名" --verbose

这里我们一般使用github邮箱和用户名, 然后在你的邮箱中会收到确认邮件, 在浏览器中点击链接确认即注册成功, 成功之后可以终端执行:

pod trunk me

查看自己的注册信息, 以后当你有了自己的开源Pod库, 也可以用此方式随时查看自己发布过的Pods;

2、创建共享库文件并上传到公有仓库

共享库需要三个必不可少的部分:
A. 共享文件夹(文件夹存放着你要共享的内容, 也就是其他人pod得到的文件, .podspec文件中的source_files需要指定此文件路径及文件类型);
B. LICENSE文件(默认一般选择MIT);
C. 库描述文件.podspec(本库的各项信息描述, 需要提交给CocoaPods, pod通过这个文件查找到你共享的库, .podspec文件的格式见第3点).

这一步分两种情况:
A.如果你已经有了现成的想要共享的文件,你只需要满足上面三个部分,即可上传到公有仓库即可继续其他的步骤;
B.你想要创建一个全新的工程去做自己的共享, 可以使用终端命令:

pod lib create 库名

去根据需要选择各项配置后创建一个标准的工程, 这里不做赘述, 具体请参考:Using Pod Lib Create;

你可以使用SourceTree等工具上传你的代码到公共仓库, 关于如何使用命令行上传代码到远端仓库, 可以移步:iOS开发使用Git那些事, 这里不做赘述.

3、编辑.podspec文件

JM_ActionSheet.podspec为例:

Pod::Spec.new do |s|
    s.name         = "JM_ActionSheet"
    s.version      = "1.0.1"
    s.summary      = "An ActionSheet like WeChat"
    s.homepage     = "https://github.com/ZJM6658/ActionSheetLikeWeChat"
    s.license      = "MIT"
    s.authors      = {"JM Zhu" => "815187811@qq.com"}
    s.platform     = :ios, "6.0"
    s.source       = {:git => "https://github.com/ZJM6658/ActionSheetLikeWeChat.git", :tag => s.version}
    s.source_files = "JM_ActionSheet/*.{h,m}"
    s.requires_arc = true
end

这是一个最简单的.podspec文件样式, 各项属性的意思一目了然, 如果本库中有依赖其他库, 加上`s.dependency "库名"即可.

编写完成后, 我们需要验证.podspec文件的合法性, 这里需要终端cd到.podspec文件所在文件夹, 执行:

pod lib lint JM_ActionSheet.podspec

如有警告或者错误请重新检查你的编写正确性, 如果没有问题会出现

-> JM_ActionSheet (1.0.1)
    
JM_ActionSheet passed validation.
4、打tag, 发布一个release版本

一切准备就绪后, 我们需要在你的git仓库里面存在一个与.podspec文件中一致的version, 这里你可以在你的git仓库中的releases一项去手动发布, 也可以在当前文件夹下使用终端命令:

git tag -m "first release" "1.0.1"
git push --tag #推送tag到远端仓库

成功之后即可在你的releases里面看到这个tag的版本.

5、发布自己的库描述文件podspec给cocoapods

同样在这个文件夹下, 终端执行:

pod trunk push JM_ActionSheet.podspec

将你的库文件.podspec文件提交到公有的specs上面, 这一步做的操作是验证你的podspec文件是否合法+提交到specs中(等同于fork;commit;push)+将上传的podspec文件转成json格式文件),成功后会出现Congrats信息噢~

6、关于查找和使用新创建的库

成功后需要等待的时间不定, 目前一般比较快, 一般使用pod setup和pod search查看是否已经可以使用, 本人创建这个库之后一个星期内每天尝试pod setuppod search JM_ActionSheet始终无法查找到自己的库, 查找资料之后找到解决办法:

1.pod setup成功后生成的~/Library/Caches/CocoaPods/search_index.json文件, 是用来查找的索引文件, 终端输入:

    rm ~/Library/Caches/CocoaPods/search_index.json

删除~/Library/Caches/CocoaPods目录下的search_index.json文件, 删除成功后再执行:pod search 库名, 等待输出:Creating search index for spec repo "master".. Done! 稍等片刻就会出现你想要的结果~

7、更新维护podspec

如果有错误或者需要迭代版本,修改工程文件后推送到远端仓库后, 需要修改podspec中的版本号, 并重新打tag上传, 再进行新一轮的验证和发布, 当然, 创建一个演示demo工程供其他开发者下载查看并不会影响我们的pod库.

二. 创建私有Pod库

私有Pod库和公有Pod库的创建方式没有什么区别, 不一样的是管理他们的spec repo不一样
所以我们需要自己创建一个跟CocoaPods/Specs类似的仓库来管理内部创建的Pod库的podspec文件, 供内部人员更新和依赖使用内部Pod组件库.
私有repo的构建形式有两种, 一种是私有git服务器上面创建,一种是本机创建.
本机创建请参考官方文档:Private Pods,
这里介绍的是在公司内部搭建的git服务器上面创建整个服务的方式.

1、创建一个git仓库用来做内部私有库的Spec Repo

在私有服务器一个仓库,一个用来存放所有共享库的podspec, 这里创建好之后的内部SSH协议地址是:git@git.yaomaitong.net:iOSPods/ymtSpecs.git, 花钱买git的私有仓库或者使用其他免费的第三方git服务(如Bitbucket等)创建的私有仓库给到的http/https地址也一样.终端输入命令:

pod repo add ymtSpecs git@git.yaomaitong.net:iOSPods/ymtSpecs.git

将ymtSpecs添加到本地repo, 添加成功后可以在/.cocoapods/repos/目录下可以看到官方的specs:master和刚刚加入的specs:ymtSpecs

如果有其他合作人员共同使用这个私有Spec Repo的话在他有对应Git仓库的权限的前提下执行相同的命令添加这个Spec Repo即可.
2、创建私有Pod组件库

继续创建一个私有仓库,用来建立需要共享的内部组件, 以Category为例:git@git.yaomaitong.net:iOSPods/Category.git, 可以创建示例工程, 像创建公有的库一样, 填写自己的podspec文件

Pod::Spec.new do |s|
    s.name         = "Category"
    s.version      = "1.0.1"
    s.summary      = "ymt Category files"
    s.homepage     = "http://git.yaomaitong.net/iOSPods/Category"
    s.license      = "MIT"
    s.authors      = {"Gua Pi" => "guapi@yaomaitong.cn"}
    s.platform     = :ios, "7.0"
    s.source       = {:git => "http://git.yaomaitong.net/iOSPods/Category.git", :tag => s.version}
    s.source_files = "AllCategory/*.{h,m}"
    s.requires_arc = true
end

值得注意的是:podspec文件中的homepage和source不支持ssh协议地址,所以我们得放入http/https地址.

与公有库的创建方式一样, pod lib lint Category.podspec验证成功之后push到仓库, 然后打tag发布release版本.

3、然后将podspec加入私有Sepc repo中

公有库使用trunk方式将.podspec文件发布到CocoaPods/Specs, 内部的pod组件库则是添加到我们第一步创建的私有Spec repo中去, 在终端执行:

    pod repo push ymtSpecs Category.podspec

添加成功之后ymtSpecs中会包含Category库的podspec信息, 可以前往~/.cocoapods/repos下的ymtSpecs文件夹中查看, 同时git服务器中的远端也更新了.

4、查找和使用内部组件库

执行pod search Category就能查到刚刚创建好的Category库了, 然后在想要使用此组件的工程的Podfile中加入pod "Category", "~>1.0.1"即可使用内部组件啦!

值得注意的是:必须在Podfile前面需要添加你的私有Spec repo的git地址source, pod install时, 才能在私有repo中查找到私有库, 像这样:

    source "git@git.yaomaitong.net:iOSPods/ymtSpecs.git"
    
    platform :ios, "7.0"
    target "test" do
        pod "Category", "~>1.0.1"
    end

经过测试, 这种方式可以把你的所有可以拆分出来的组件, 甚至是业务都来使用Pod管理, 这样达到了解耦和单项更新优化某些组件不影响老版本的依赖使用, 出现问题修改Podfile中的依赖版本即可随时回滚, 给开发了带来极大的便利, 值得学习.

小小的更新

有同学表示私有库与公有库同时使用有报错,这个时候你在Podfile中把公有源加上就可以的:
source "https://github.com/CocoaPods/Specs.git"

如果实践中有任何问题,可以加我QQ:815187811,互相交流学习。

参考链接:
CocoaPods Guides
Private Pods
手把手教你发布代码到CocoaPods(Trunk方式)
使用Cocoapods创建私有podspec
COCOAPODS创建私有PODS

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/16572.html

相关文章

  • 组件化实践

    摘要:最近想了解一些组件化的知识,去看了写的应用架构谈组件化方案这篇文章,在文中针对蘑菇街的组件化方案提出了一些不同的观点,陈述了自己的组件化方案。准备首先我们得先了解组件化这个概念,其实通俗的讲,就是把我们的项目拆解成一个一个的小组件分别管理。 最近想了解一些组件化的知识,去看了Casa写的iOS应用架构谈 组件化方案这篇文章,Casa在文中针对蘑菇街的组件化方案提出了一些不同的观点,陈述...

    Galence 评论0 收藏0
  • Cocoapods整理(四)——搭建Cocoapods私有环境

    摘要:整理四搭建私有库环境目录前言搭建私有库环境其他的一些技巧前言在懂得如何写之后,我们来创建一个自己的私有库吧。所以如果想要搭建私有库环境,则需要创建一个类似于官方的库,让这个库去保存自己写的三方库的文件。 Cocoapods整理(四)——搭建Cocoapods私有库环境 目录 前言 搭建Cocoapods私有库环境 其他的一些技巧 前言 在懂得如何写podspec之后,我们来创建...

    Simon 评论0 收藏0
  • Cocopods应用及插件

    摘要:静态库一堆目标文件的打包体并非二进制文件。加载静态库启动时,动态库使用时启动后。四其它插件参考链接插件安装及说明参考链接官网安装教程文件的具体说明发布开源库到官方仓库动态库和静态库分析 声明: 最后更新时间:2019年3月18日 为保证时效性,持续更新地址为:Cocopods安装和使用 一、安装和使用Cocopods 网上已有很多教程,参考示例:CocoaPods安装教程 二、让...

    OldPanda 评论0 收藏0
  • iOS进阶学习

    摘要:小试推出的是今年新推出面向开发者的机器学习框架。精简的网络封装不依赖第三方库精简的网络封装不依赖第三方库多线程开发之是苹果提供的一套多线程解决方案。 iOS 内存探秘 本文深入浅出的介绍了 iOS 系统的内存机制以及开发者所需要注意的问题 GMTC 上分享滴滴出行 iOS 端瘦身实践的 Slides 滴滴出行 iOS 端瘦身实践 iOS之widget开发(Today Extension...

    187J3X1 评论0 收藏0
  • 玩转CocoaPods

    摘要:使用,版本号范围,版本号范围,版本号范围,无意义实际使用时,可根据项目需求,灵活配置依赖版本号。满足中指定版本号条件下,列出比中记录锁定的版本号新的。方法,仍通过集成,但和必须修改为同一标识,集成时显式指定版本号。 摘要: 作者:阿里-移动云-大前端 CocoaPods作为iOS的依赖管理工具,已然成为iOS开发的标准工具(官方给出的数据,超过42W个库和300W个App使用了Coco...

    LiveVideoStack 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<