美文网首页实用工具iOS八宝粥
CocoaPods 私有仓库的创建(超详细)

CocoaPods 私有仓库的创建(超详细)

作者: BYQiu | 来源:发表于2017-03-10 13:32 被阅读6090次

    本文发布于 BY Blog简书 转载请保留链接

    前言

    最近参照了网上一大堆 CocoaPods私有仓库 的教程,按教程操作得到的pod仓库里面是这样的~

    代码和版本描述居然混在了一起,简直太糟糕~

    虽然也能用,但是和 CocoaPods 本身的理念就不相符。

    在上一篇《CocoaPods公有仓库的创建》中我们了解到,master 目录中只存放 代码库 的描述文件,而不是存放代码。就像这样

    代码我们另外存放在代码仓库中

    很多人不了解CocoaPods的工作原理就复制粘贴别人的教程来做教程~

    吐槽结束,进入正文

    正文

    创建版本库(repo)

    首先,创建一个像 master 一样的存放版本描述文件的git仓库,因为是私人git仓库,我们选择 oschina 创建远程私有仓库(因为是免费的)或者也可以在GitHub上创建($7/month)。

    下面以 oschina 为例

    创建版本描述仓库

    回到终端,将这个远程的私有版本仓库添加到本地,repo 就是 repository 储存库的缩写。

    $ pod repo add MyRepo https://git.oschina.net/baiyingqiu/MyRepo.git
    

    查看在 Finder 目录 ~/.cocoapods/repos, 可以发现增加了一个 MyRepo 的储存库

    创建代码库

    回到 oschina 创建私人代码库

    创建时添加 MIT LicenseREADME

    将仓库克隆到本地,添加你的代码文件仓库名.podspec 描述文件,还有.swift-version.

    如下

    .swift-version文件用来知道swift版本,用命令行创建

    $ echo "3.0" > .swift-version
    

    .podspec 文件是你这个代码库的pod描述文件,可以通过pod指令创建空白模板:

    $ pod spec create MyAdditions
    

    或者 强烈建议 直接拷贝下面的模板进行修改

    Pod::Spec.new do |s|
      s.name         = "MyAdditions" # 项目名称
      s.version      = "0.0.1"        # 版本号 与 你仓库的 标签号 对应
      s.license      = "MIT"          # 开源证书
      s.summary      = "私人pod代码" # 项目简介
    
      s.homepage     = "https://git.oschina.net/baiyingqiu/MyAdditions" # 仓库的主页
      s.source       = { :git => "https://git.oschina.net/baiyingqiu/MyAdditions.git", :tag => "#{s.version}" }#你的仓库地址,不能用SSH地址
      s.source_files = "MyAdditions/*.{h,m}" # 你代码的位置, BYPhoneNumTF/*.{h,m} 表示 BYPhoneNumTF 文件夹下所有的.h和.m文件
      s.requires_arc = true # 是否启用ARC
      s.platform     = :ios, "7.0" #平台及支持的最低版本
      # s.frameworks   = "UIKit", "Foundation" #支持的框架
      # s.dependency   = "AFNetworking" # 依赖库
      
      # User
      s.author             = { "BY" => "qiubaiyingios@163.com" } # 作者信息
      s.social_media_url   = "http://qiubaiying.github.io" # 个人主页
    
    end
    

    这里我要说一下一个坑,用 oschina 创建私人仓库时, 在验证时可能会找不到 MIT LICENSE证书,将其中的

    s.license      = "MIT"
    修改为,指定文件
    s.license      = { :type => "MIT", :file => "LICENSE" }
    

    然后开始验证我们的仓库配置是否正确,并按照要求进行修改

    $ pod lib lint
    

    一般出现错误警告,需要添加 --private 或者 --allow-warnings,就可以通过验证

    $ pod lib lint --private
    

    验证成功后出现

     -> MyAdditions (0.0.1)
     
    MyAdditions passed validation.
    

    将描述文件推送到版本库

    将项目打上标签推到远程仓库,标签号 和 版本号对应 都是0.0.1

    最后将我们的代码仓库的描述信息,push 到我们的版本仓库中

    $ pod repo push MyRepo MyAdditions.podspec
    

    这时会对远程仓库进行验证,成功的话就会在 ~/.cocoapods/repos/MyRep中发现新增的仓库描述信息了

    若是出现错误信息

    [!] The repo `MyRepo` at `../.cocoapods/repos/MyRepo` is not clean
    

    更新下我们的版本库,

    $ pod repo update MyRepo
    

    再继续上传即可。

    pod repo push MyRepo MyAdditions.podspec 的过程就是

    1. 验证 MyAdditions.podspec 文件
    • 拉取远程版本库 MyRepo
    • 添加 MyAdditions.podspec 到版本库中
    • push 到远程

    添加完成后我们就可以在pod中搜索

    $ pod search MyAdditions
    

    -> MyAdditions (0.0.1)
       Some category of the framework and UIKit
       pod 'MyAdditions', '~> 0.0.1'
       - Homepage: https://git.oschina.net/baiyingqiu/MyAdditions
       - Source:   https://git.oschina.net/baiyingqiu/MyAdditions.git
       - Versions: 0.0.1 [MyRepo repo]
    (END)
    

    私人pod库的使用

    使用私人pod库的需要在Podflie中添加这句话,指明你的版本库地址。

    source ‘https://git.oschina.net/baiyingqiu/MyRepo.git’
    

    注意是版本库的地址,而不是代码库的地址,很多教程都把我搞晕了~

    若有还使用了公有的pod库,需要把公有库地址也带上

    source 'https://github.com/CocoaPods/Specs.git'
    

    最后的Podflie文件变成这个样子

    source ‘https://github.com/CocoaPods/Specs.git’
    source ‘https://git.oschina.net/baiyingqiu/MyRepo.git’
    
    platform :ios, '8.0'
    
    target ‘MyPodTest’ do
    use_frameworks!
    
    pod “BYPhoneNumTF” #公有库
    pod ‘MyAdditions’ #我们的私有库
    pod ‘BYAdditions’ #这是我又添加到版本库中的另一个代码库
    
    end
    

    测试:

    $ pod install
    

    加载完成可以看到代码已经整合到我们的项目中了

    perfect!

    回到Fender中 ~/.cocoapods/repos,会发现 repos 中增加了一个pod版本库。

    执行 pod install 命令时

    • 会拉取远程 Podfliesource 标记 版本库 到本地的 repos 文件夹中

    • 在 版本库 中搜索我们pod ‘MyAdditions’MyAdditions.podspec 文件。

    • 根据 MyAdditions.podspec 文件中描述的源码地址下载并整合到项目中

    结语

    通过 《CocoaPods私有仓库的创建》《CocoaPods公有仓库的创建》这两篇文章,相信大家对CocoaPods的工作原理都有了更深层次的了解。

    在写博客和和创建的过程中,踩了不少的坑(😀前人教程留下的),很多的东西只有自己操作完才能真正的领会。

    最后,如果本文有什么错误或者有什么不同的观点欢迎提出交流。😉

    相关文章

      网友评论

      • zhangferry:我是想将原来远程仓库中的代码变成私有cocoapods,当执行pod repo add 时就将原代码都拉倒.cocoapods/repo文件中了,怎么将这里的代码分出去呢
      • 铃鹿山大魔王:很好,我也写了一篇类似的文章,几乎翻译自官网 https://www.jianshu.com/p/c94d394f0be7
        铃鹿山大魔王:@BYQiu 按照官网的操作躺了一趟,几乎一步到位了。
        BYQiu:@暗恋学妹的煎饼果子 翻译得很好呢,不过我认为 教程 是将文档的操作走一遍,然后在将这个过程写出来的,并提出自己的心得避免别人踩坑哈。
      • 杜小七:好像库的版本只能创建一次,之后同一版本号就不能更新了。
        例如一个库common下有一个basecontroller ,走发布流程, 工程文件能引用了。
        但对basecontroller做了修改,再次走流程, 工程文件update下来的却一直是旧的代码。 有遇到这个问题吗? 还是我更新的操作不对。
      • 猪猪行天下:设置的仓库为私有的,pod install的时候却连接不到仓库。设置为公开的时候就可以。你没有这个问题嘛?
        铃鹿山大魔王:@猪猪行天下 你需要指明私有仓库的source源,也就是你那个私有的Repo的git地址,不是代码仓库地址。
        猪猪行天下:@暗恋学妹的煎饼果子 指明了source源,但是仓库为私有的。
        铃鹿山大魔王:你需要指明source源,例如source ‘https://github.com/CocoaPods/Specs.git’,在Podfile文件中。
      • Ly梦k:终端直接报错:The `MyAdditions.podspec` specification does not validate.是下面哪里不对?
        MyAdditions.podspec文件如下:#
        # Be sure to run `pod spec lint MyAdditions.podspec' to ensure this is a
        # valid spec and to remove all comments including this before submitting the spec.
        #
        # To learn more about Podspec attributes see http://docs.cocoapods.org/specification.html
        # To see working Podspecs in the CocoaPods repo see https://github.com/CocoaPods/Specs/
        #

        Pod::Spec.new do |s|

        s.name = "MyAdditions" # 项目名称
        s.version = "0.0.1" # 版本号 与 你仓库的 标签号 对应
        s.license = "MIT" # 开源证书
        s.summary = "私人pod代码" # 项目简介

        s.homepage = "https://gitee.com/qingfengiOS/MyAdditions"; # 仓库的主页
        s.source = { :git => "https://gitee.com/qingfengiOS/MyAdditions.git";, :tag => "#{s.version}" }#你的仓库地址,不能用SSH地址
        s.source_files = 'MyAdditions/MyAdditions/*.{h,m}' # 你代码的位置, BYPhoneNumTF/*.{h,m} 表示 BYPhoneNumTF 文件夹下所有的.h和.m文件
        s.requires_arc = true # 是否启用ARC
        s.platform = :ios, "7.0" #平台及支持的最低版本
        # s.frameworks = "UIKit", "Foundation" #支持的框架
        # s.dependency = "AFNetworking" # 依赖库

        # User
        s.author = { "BY" => "qiubaiyingios@163.com" } # 作者信息
        s.social_media_url = "http://qiubaiying.github.io"; # 个人主页

        end
      • iOSugarCom:感谢作者,帮我理清楚了原来挺模糊的概念,版本归版本库,代码放在其他地方,尝试了一下,可以,依赖外部公有库的问题,也提到了 ``若有还使用了公有的pod库,需要把公有库地址也带上`` 吹毛求疵一下,下面的代码的单引号是中文的,会报一个警告。再次感谢!
        BYQiu:@iOSugar_com 感谢指出
      • Hwangkop:楼主您好,我在更新的时候出现错误:[!] The repo `MyRepo` at `../.cocoapods/repos/MyRepo` is not clean
        然后使用:$ pod repo update MyRepo
        然后再:pod repo push MyRepo xxx.podspec 的时候还是出现以上错误,可否帮分析分析
        BYQiu:@Hwangkop 他的提示说需要清除,你需要看看哪个步骤出了问题
        Hwangkop:@BY_Qiu 这样确实可以,但是每次更新,都要进去删除...
        BYQiu:进入 ~/.cocoapods/repos 删除这个MyRepo仓库再试试

      本文标题:CocoaPods 私有仓库的创建(超详细)

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