iOS - CocoaPods 第三方开源框架管理

简介: 1、CocoaPodsCocoaPods 是一个负责管理 iOS 项目中第三方开源库的工具。CocoaPods 的项目源码在 Github 上管理。该项目开始于 2011 年 8 月 12 日,在这两年多的时间里,它持续保持活跃更新。

1、CocoaPods

  • CocoaPods 是一个负责管理 iOS 项目中第三方开源库的工具。CocoaPods 的项目源码在 Github 上管理。该项目开始于 2011 年 8 月 12 日,在这两年多的时间里,它持续保持活跃更新。开发 iOS 项目不可避免地要使用第三方开源库,CocoaPods 的出现使得我们可以节省设置和更新第三方开源库的时间,在 iOS 开发中经常会用到第三方库如 AFNetworking,ASIHttpRequest 等,在使用第三方库时,你除了要导数源码外,但是,集成这些依赖库需要我们手动去配置,还有当这些第三方库发生了更新,还需要手动去更新项目。这就显得非常麻烦。有麻烦自然有解决办法,CocoaPods 就是为了解决这个问题而生的。通过 CocoaPods,我们可以将第三方的依赖库统一管理起来,配置和更新只需要通过简单的几行命令即可完成。

  • 1)安装:

        # 查看 Ruby 源
        $ gem sources –l
    
        # 添加新的 Ruby 源
        $ sudo gem sources -a https://ruby.taobao.org/
    
        # 移除现有 Ruby 默认源
        $ sudo gem sources -r https://rubygems.org/
    
        # 安装 cocoapods
        # 苹果系统升级 OS X EL Capitan 后改为:$ sudo gem install -n /usr/local/bin cocoapods
        $ sudo gem install cocoapods
    
        # 设置/更新本地 cocoapods 仓库
        $ pod setup
  • 2)使用:

        # 新建工程,并在终端用 cd 指令打开到工程文件夹内
    
        # 搜索第三方框架
        $ pod search 第三方框架
    
        # 新建文件,写入以下内容并保存
        $ vim Podfile
    
            platform :ios, '8.0'
            target '项目名称' do                 // 最新版本的需要加该句
            pod 'AFNetworking', '~> 3.1.0'      // 可以直接从搜索到的第三方框架中复制
            end
    
        # 上一步操作可以直接用下面的指令一步完成
        $ echo -e "target '项目名称' do\npod 'AFNetworking', '~> 3.1.0'\nend" > Podfile
    
        # 安装/下载第三方框架
        $ pod install
    
        # 添加/下载第三方框架
    
            pod 'AFNetworking', '~> 3.1.0’      // 升级到最新版本
            pod 'SDWebImage', '~> 3.8.1’        // 下载并添加进工程中
    
        $ pod update
  • 3)pod 常用命令:

        .podspec 文件是 用于初始化本地第三方库的 spec 描述文件,所有的 spec 文件存都存放在 ~/.cocoapods 目录中。
    
        # 设置/更新本地 cocoapods 仓库
        $ pod setup
    
        # 安装/下载第三方框架
        $ pod install
    
        # 添加/下载第三方框架
        $ pod update
    
        # 列出本地 cocoapods 仓库所有可用的第三方框架
        $ pod list
    
        # 在本地 cocoapods 仓库中搜索名称为 query 的第三方框架
        $ pod search query
    
        # 更仔细的搜索,该命令不但搜索类库的名称,同时还搜索类库的描述文本,所以搜索速度也相对慢一些。
        $ pod search --full query
    
        # 更新本地 cocoapods 仓库中第三方框架的描述文件
        # pod list 和 pod search 命令只搜索存在于本地 ~/.cocoapods 文件夹的所有第三方框架,并不会连接到远程服务器
        $ pod repo update master
    
        $ pod repo update --verbose     // 更新时显示详细信息
    
        # 创建一个 podspec 文件
        $ pod spec create Name.podspec
    
        # 注册 trunk
        # EmailAddr:邮箱地址,userName:用户名,--verbose:输出调试信息
        $ pod trunk register EmailAddr 'userName' --verbose
    
        # 向服务器查询自己的注册信息
        $ pod trunk me
    
            输出如下信息就表示注册成功:
    
                - Name:     QianChia
                - Email:    jhqian0228@icloud.com
                - Since:    July 17th, 06:26
                - Pods:
                    - QConnectionDownloader
                    - QFormData
                    - QHashString
                    - QSessionDownloader
                    - QWebImage
                - Sessions:
                    - July 17th, 06:26 - November 23rd, 01:33. IP: 43.225.238.143
    
        # 验证 podspec 文件是否合法
        $ pod lib lint Name.podspec
    
        # 通过 trunk 推送 podspec 文件
        $ pod trunk push Name.podspec
    
        # Usage:
    
            $ pod COMMAND
    
                CocoaPods, the Cocoa library package manager.
    
        # Commands:
    
            + cache         Manipulate the CocoaPods cache
            + deintegrate   Deintegrate CocoaPods from your project
            + env           Display pod environment
            + init          Generate a Podfile for the current directory
            + install       Install project dependencies according to versions from a Podfile.lock
            + ipc           Inter-process communication
            + lib           Develop pods
            + list          List pods
            + outdated      Show outdated project dependencies
            + plugins       Show available CocoaPods plugins
            + repo          Manage spec-repositories
            + search        Search for pods
            + setup         Setup the CocoaPods environment
            + spec          Manage pod specs
            + trunk         Interact with the CocoaPods API (e.g. publishing new specs)
            + try           Try a Pod!
            + update        Update outdated project dependencies and create new Podfile.lock
    
        # Options:
    
            --silent        Show nothing
            --version       Show the version of the tool
            --verbose       Show more debugging information
            --no-ansi       Show output without ANSI codes
            --help          Show help banner of specified command
  • 4)常见问题:

    • 问题 1:

          Error fetching http://ruby.taobao.org/:
          bad response Not Found 404 (http://ruby.taobao.org/specs.4.8.gz)
      
          解决方案:把安装流程中 $ gem sources -a http://ruby.taobao.org/ 改为 $ gem sources -a https://ruby.taobao.org/
    • 问题 2:

          ERROR: While executing gem ... (Errno::EPERM)
          Operation not permitted - /usr/bin/pod
      
          解决方案:苹果系统升级 OS X EL Capitan 后会出现的插件错误,将安装流程中的 $ sudo gem install cocoapods 改为 
                   sudo gem install -n /usr/local/bin cocoapods
    • 问题 3:

          ERROR:  Error installing cocoapods:
          activesupport requires Ruby version >= 2.2.2.
      
          解决方案:输入 $ ruby -v 查看 ruby 版本:ruby 2.0.0p648 (2015-12-16 revision 53162) [universal.x86_64-darwin15],
                   版本过低,使用 RVM 对 Ruby 进行升级。
    • 问题 4:

          [!] Unable to satisfy the following requirements:
          - `AVOSCloud (~> 3.1.6.3)` required by `Podfile`
      
          Specs satisfying the `AVOSCloud (~> 3.1.6.3)` dependency were found, but they required a higher minimum deployment target.
      
          解决方案:安装流程中的 Podfile 文件中 platform:ios, ‘6.0’ 后边的 6.0 是平台版本号 ,一定要加上。
    • 问题 5:

          [!] The dependency `AFNetworking (~> 3.1.0)` is not used in any concrete target.
      
          解决方案:百度上很多旧版本输入的类容:
      
              platform :ios, '8.0'
              pod 'AFNetworking', '~> 2.0'
      
          现在版本升级官方给的文档是:
      
              platform :ios, '8.0'
      
              target '项目名称' do
              pod 'AFNetworking', '~> 3.1.0'
              end
    • 问题 6:

          [!] Your Podfile has had smart quotes sanitised. To avoid issues in the future, you should not use TextEdit 
          for editing it. If you are not using TextEdit, you should turn off smart quotes in your editor of choice.
      
          解决方案:不要使用文本编辑去编辑 Podfile,使用 Xcode 编辑,或者使用终端敲命令去编辑。
    • 问题 7:

          /usr/local/bin/pod update
          env: ruby_executable_hooks: No such file or directory
      
          在 Xcode 的 CocoaPods 插件中使用 pod update 出现以上提示。
      
          解决方案:在终端里输入 $ gem env 找到 SHELL PATH,修改 Xcode 的 cocoapods 插件里 GEM_PATH 选项为上面得到的路径,
                   挨着试试总会成功的。
    • 问题 8:

          有一些库编译时候会有警告。但是作为一个有洁癖的人呢不想看见这些。
      
          解决方案:可以在 platform :ios, ‘x.0’ 的后面加入这句,这样编译这些第三方库的时候就没有那些烦人的小警告了。
      
              inhibit_all_warnings!
    • 问题 9:

          但是有一个库 ReactiveCocoa。当关闭所有警告的时候。它就编译不过了。
      
          解决方案:对他单独设置打开编译警告就好了。
      
              pod 'ReactiveCocoa', '~> 2.1.8', :inhibit_warnings => true
    • 问题 10:

          如果有多个 Targets 需要 pod 的库怎么办。
      
          解决方案:Podfile 的头部加入以下代码,AAAAA 和 BBBBB 都是你 target 的名字,这样不同的 target 都会有 pod 库了。
                   主要是用来解决 Unit Test 需要 pod install 一些库的问题。
      
              link_with ['AAAAA', 'BBBBB']
    • 问题 11:

          [!] The `master` repo is not a git repo.
      
          原因:修改了 Xcode.app 的路径后,找不到 Xcode
      
          解决:终端执行即可
              sudo xcode-select -switch /Applications/Developer/Xcode.app(Xcode 实际路径)
    • 问题 12:

          [!] The specified path `QExtension.podspec` does not point to an existing podspec file.
      
          原因:没有进入到 .podspec 文件所在的文件夹
      
          解决:cd 进入到 .podspec 文件所在的文件夹
    • 问题 13:

          创建工程使用 cocoapods 时没有出现 xcworkspace 文件解决方法。
      
          // 更新 cocoapods
          sudo gem install -n /usr/local/bin cocoapods
      
          // 在工程目录下 
          pod install

2、gem 常用命令

    # 查看 Ruby 源
    $ gem sources –l
    
    # 添加源
    $ sudo gem sources -a https://ruby.taobao.org/
    
    # 删除源
    $ sudo gem sources -r https://rubygems.org/
    
    # gem 自身升级
    $ sudo gem update –system
    
    # 查看版本
    $ gem --version
    
    # 清除过期的 gem
    $ sudo gem cleanup
    
    # 安装包
    # 苹果系统升级 OS X EL Capitan 后改为:$ sudo gem install -n /usr/local/bin cocoapods
    $ sudo gem install cocoapods
    
    # 删除包
    $ gem uninstall cocoapods
    
    # 更新包
    $ sudo gem update
    
    # 列出本地安装的包
    $ gem list

3、Ruby 源

    “源” 相当于安装软件的服务器。
    
    国外的源地址:https://rubygems.org/        速度非常慢慢
    国内的源地址:https://ruby.taobao.org/     速度快
     
    # 查看当前 ruby 版本
    $ ruby -v
     
    # 列出已知的 ruby 版本,需安装 RVM 管理器
    $ rvm list known
     
    # 升级 Ruby 版本,需安装 RVM 管理器
    $ rvm install 2.3.0

4、RVM 管理器

    RVM:Ruby Version Manager,Ruby 版本管理器,包括 Ruby 的版本管理和 Gem 库管理(gemset)
     
    # 安装 RVM:
    $ curl -L get.rvm.io | bash -s stable
    $ source ~/.bashrc
    $ source ~/.bash_profile
     
    # 查看 RVM 版本
    $ rvm -v

5、安装 Xcode 插件管理器

    curl -fsSL https://raw.github.com/supermarin/Alcatraz/master/Scripts/install.sh | sh
    
    安装完 Xcode 插件管理器后,在 Xcode 的菜单 Window 中多出一个 Package Manager 选项,用于管理 Xcode 插件的安装与卸载。
     
    如果安装了 CocoaPods,在 Xcode 的菜单 Product 中多出一个 CocoaPods 选项,用于管理工程中用到的第三方框架。
目录
相关文章
|
1天前
|
缓存 安全 前端开发
美团 iOS 端开源框架 Graver 在动态化上的探索与实践
美团 iOS 端开源框架 Graver 在动态化上的探索与实践
|
1月前
|
Android开发 iOS开发 开发者
App备案-iOS云管理式证书 Distribution Managed 公钥及证书SHA-1指纹的获取方法
App备案-iOS云管理式证书 Distribution Managed 公钥及证书SHA-1指纹的获取方法
226 0
|
1月前
|
监控 API Swift
用Swift开发iOS平台上的上网行为管理监控软件
在当今数字化时代,随着智能手机的普及,人们对于网络的依赖日益增加。然而,对于一些特定场景,如家庭、学校或者企业,对于iOS设备上的网络行为进行管理和监控显得尤为重要。为了满足这一需求,我们可以利用Swift语言开发一款iOS平台上的上网行为管理监控软件。
224 2
|
1月前
|
iOS开发 开发者
App备案与iOS云管理式证书 ,公钥及证书SHA-1指纹的获取方法
App备案与iOS云管理式证书 ,公钥及证书SHA-1指纹的获取方法
385 0
|
1月前
|
Android开发 iOS开发 开发者
App备案-iOS云管理式证书 Distribution Managed 公钥及证书SHA-1指纹的获取方法
App备案-iOS云管理式证书 Distribution Managed 公钥及证书SHA-1指纹的获取方法
142 0
|
6月前
|
iOS开发 开发者
📝 App备案与iOS云管理式证书 ,公钥及证书SHA-1指纹的获取方法
在iOS应用程序开发过程中,进行App备案并获取公钥及证书SHA-1指纹是至关重要的步骤。本文将介绍如何通过appuploader工具获取iOS云管理式证书 Distribution Managed 公钥及证书SHA-1指纹,帮助开发者更好地理解和应用该过程。
|
7月前
|
Android开发 iOS开发 开发者
App备案-iOS云管理式证书 Distribution Managed 公钥及证书SHA-1指纹的获取方法
,在appuploder直接复制IOS信息;如果还没有创建证书,请上传正确的P12苹果证书后,系统会自动解析出对应的签名和公钥信息; ——APP备案的原理是基于原有的工信部域名备案系统,如果已经有了域名备案,无需新增备案主体;只需要在之前的域名备案系统里面,新增APP信息,收集的APP信息主要包括APP包名和签名及公钥这3项;——APP备案是属于行政常规主体信息预存,和域名一样,自行决定是否备案。目前国内安卓应用商店是全面要求APP备案的,如果没有APP备案是不能通过审核发布到各大应用商店。——如看了教程,还不清楚怎么获取APP包名、安卓签名、苹果sha1签名、公钥等信息,请联系我们在线客服,
|
8月前
|
数据安全/隐私保护 Android开发 iOS开发
解决第三方邮箱APP登陆QQ、163邮箱无法验证账户名或密码的问题(IOS、MacOS、Windows、Android)
解决第三方邮箱APP登陆QQ、163邮箱无法验证账户名或密码的问题(IOS、MacOS、Windows、Android)
142 0
|
9月前
|
iOS开发 Perl
iOS Cocoapods 升级
iOS Cocoapods 升级
74 0
|
9月前
|
网络协议 Swift iOS开发
iOS CocoaPods
iOS CocoaPods
58 0