手把手教你利用cocoapod搭建私有库

作者: 贺彦文 | 来源:发表于2016-11-22 12:57 被阅读748次

    0.前言

    现在越来越多的项目开始考虑组件化开发了,因此使得cocoapod搭建私有库成为一个必备的首要的技能。如同很多技术一样,搭建环境是最烦人的一步,相信很多人都会死在第一步搭建环境上。笔者我也是看着各种资料琢磨了半个多月终于搭起来的。看资料的过程是很烦人的,因为好多文章都是东拼西凑,感觉写文章的人都没有实际运行他写的步骤,特别让人讨厌。因此我搭建的必须是亲自一步步实践过的。应该不让您失望。

    1.简单介绍几个概念

    三方库的目录表specs:终端输入cd ~/.cocoapods/repos/master可看到里面放的都是一个个的podspec文件大小仅仅为几KB,是三方库的索引文件。
    私有库目录表的远程仓库:是目录表文件的远程存放地址。
    私有库的远程仓库:这是我们自己写的想作为一个组件的代码。
    行了就这三个概念,简单吧。

    2.开始上具体组件代码

    • 2.1 首先创建两个远程仓库
    git.oschina创建索引spec仓库
    这个AutoziBaseSpec仓库只存放索引文件,占用很小就几kb。 autoziBase实际代码的仓库
    这个AutoziBase仓库存放的代码
    • 2.2 把要写具体代码的仓库拷下来,写入具体的组件代码
    把实际代码仓库clone下来
    cd Desktop/
    git clone https://git.oschina.net/heeween/AutoziBase.git 
    
    • 2.3 我这里直接拷贝了我的一些base文件和分类文件
    桌面上组件代码的示意图
    • 2.4 创建pod描述文件,让组件代码具有被cocoapod管理的能力
    cd /Users/heew/Desktop/AutoziBase
    pod spec create AutoziBase
    

    这个时候会在桌面的项目文件中多了一个podspec文件


    现在的项目文件夹结构
    • 2.5 编辑podspec描述文件,主要就是讲清楚你这个私有库的地址和依赖关系等,下面是必须修改才能通过的地方
    s.platform     = :ios, "9.0"
    s.source       = { :git => "https://git.oschina.net/heeween/AutoziBase.git", :tag => "#{s.version}" }
    s.source_files  = "Base", "Category"
    s.dependency 'Alamofire', '~> 4.0.1'
    s.dependency 'SnapKit', '~> 3.0.2'
    s.dependency 'SVProgressHUD', '~> 2.0.3'
    s.dependency 'SwiftyJSON', '~> 3.1.1'
    s.dependency 'Kingfisher', '~> 3.2.0'
    

    我这里的组件化Base和Category里的代码依赖了5个知名的三方库,而alamofire在swift3.0中必须要求项目版本最低9.0,因此有了上面的设置。

    • 2.6 设置完了以后,在终端中验证下AutoziBase这个项目是否真的具有了被cocoapod管理的能力,注意要添加allow-warning才可以通过。
    pod lib lint --verbose --allow-warnings
    

    基本上设置了以前的几个必要选项,基本上也没其他关键设置了,所以应该就可以通过了。或者你也可以直接任意下载一个知名的第三方库,cd到库里,运行pod lib lint --verbose可以详细看看别人的代码具体是怎么通过验证的。

    • 2.7 给组件库打tag,并上传到git服务器,注意还是在AutoziBase代码的目录下执行一下命令
    git add .
    git commit -m "添加了base和category代码"
    git tag -a 0.0.1 -m "添加0.0.1tag"
    git push origin --tags
    git push
    
    上传以后的组件代码仓库就有了具体的代码

    所有以上操作全是在操作组件化代码,操作的目录也都是在AutoziBase这个项目的目录下。接着开始整项目索引文件

    3.开始着手项目的索引文件

    • 3.1把远程spec复制到本地pod管理目录文件夹中
    pod repo add AutoziBaseSpec https://git.oschina.net/heeween/AutoziBaseSpec.git
    cd ~/.cocoapods/repos/
    open .
    

    这时系统中.cocoapod的本地文件夹就出现了我们自己的项目索引文件AutoziBaseSpec文件

    本地cocoapod文件夹结构
    • 3.2一句代码添加刚才验证好的podsec到本地这个文件夹并且上传到远程目录管理服务器
      注意这个时候必须回到AutoziBase这个具体项目的目录下来执行
    cd /Users/heew/Desktop/AutoziBase 
    pod repo push AutoziBaseSpec AutoziBase.podspec --verbose --allow-warnings
    
    • 必须回到AutoziBase具体项目的目录下
    • 虽然是git上传但口令是pod repo push,不是git push
    • AutoziBaseSpec写的是项目索引的名称,不是项目名称
    • AutoziBase.podspec 是具体项目的描述文件podspec,就是刚才验证通过的文件
    • 要加--allow-warnings 因为我们的描述文件有些不规范的地方

    现在再看看项目描述远程仓库的样子

    只有一个AutoziBase文件夹
    里面是AutoziBase描述文件

    到现在所有配置就结束了

    4.怎么使用

    • 4.1创建一个demo项目来用用吧
    xcode创建一个demo名称的工程,退出
    cd /Users/heew/Desktop/demo 
    pod init 
    pod search AutoziBase
    
    • 4.2搜索自己的私有库
      终端中搜索到自己的私有库,这一步就很有成就感了,看图


      私有库的介绍

    这时编辑demo项目中多出的podfile文件,如下

    • 4.3 编辑podfile
      特别注意要添加两个源,并且使用use_frameworks
    source 'https://github.com/CocoaPods/Specs.git'
    source 'https://git.oschina.net/heeween/AutoziBaseSpec.git'
    target 'demo' do
    use_frameworks!
    pod 'AutoziBase', '~> 0.0.1'
    end
    
    • 4.4最后的安装组件
      终于到最后一步安装了
    pod install
    

    相关文章

      网友评论

      • littleDad:很棒 ,大兄弟这么详细,一次 就成功了。你狠优秀
        贺彦文:@小米_加步枪 按照提示是让以双引号的方式 导入BeautyKitMacro.h 你试试
        littleDad:@贺彦文 大兄弟 ,我昨天 私有库 依赖 私有库,在 pod repo push 时候,控制台提示 头文件查找不到,ERROR | xcodebuild: BGAlertView/BGAlertViewDemo/BGAlertView/BGAlertViewHeader.h:13:9: error: 'BeautyKitMacro.h' file not found with <angled> include; use "quotes" instead

        这个 有没有 破功的方式,查了好久资料没有 结果 ....
        贺彦文:多谢多谢 还是你领悟能力好
      • 对酒当歌的夜:按照步骤来的,到最后还是搜不到自己的项目怎么破
        对酒当歌的夜:@贺彦文 搞定了 ,自己的pod名称是配置里面的那个name,不是项目名称,
        贺彦文:@对酒当歌的夜 可能有点多,pod repo push成功了?

      本文标题:手把手教你利用cocoapod搭建私有库

      本文链接:https://www.haomeiwen.com/subject/kdjppttx.html