CocosPods安装教程以及使用

CocoaPods简介

CocoaPods是一个管理Swift和Objective-C的Cocoa项目的依赖工具。它现在有超过一万八千多个库,可以优雅地帮助你扩展你的项目。简单的说,就是替你管理Swift和Objective-C的Cocoa项目的第三方库引入。

官网地址: https://cocoapods.org/

注:要使用CocoaPods,那就要下载安装它,而下载安装CocoaPods需要Ruby环境

 

1、Ruby环境搭建

当前安装环境为Mac mini 10.8.5。Mac  OS本身自带Ruby,但还是更新一下保险,因为我第一次安装在没有更新Ruby的情况下就失败了。

a 查看下当前ruby版本:打开终端输入 ruby -v(确实安装了,不过用这个版本接下来工作失败了,所以更新下ruby)

b 有时候在安装cocoapods时会产生如下错误

ERROR:  Error installing cocoapods: activesupport requires Ruby version >= 2.2.2.
所以,最好先更新ruby版本。

通过rvm安装Ruby详细步骤:

1>安装 rvm 
RVM:Ruby Version Manager,Ruby版本管理器,包括Ruby的版本管理和Gem库管理(gemset)

  1. $ curl -L get.rvm.io | bash -s stable  
  2. 等待一段时间后就可以成功安装好 RVM。
  1. $ source ~/.bashrc  
  2. $ source ~/.bash_profile 
  3. 测试是否安装正常,(以上两个命令行敲了不会显示什么,但是需要敲)
  4. rvm -v  
  5. 显示版本,会出现下边的样子

2、用RVM升级Ruby

主要是第五行,看一下当前的版本有哪些?然后第七行安装个版本高点的(老板,来个2.3的)~

当然如果你看到这篇文章的时候版本可能会更高,你就别选2.3的了,版本能多高就多高吧少年.

  1. #查看当前ruby版本  
  2. $ ruby -v  
  3. ruby 2.0.0  
  4. #列出已知的ruby版本  
  5. $ rvm list known  
  6. #安装ruby 2.3 
  7. $ rvm install 2.3.0  

安装ruby可能出的错误 (若未出错, 请跳过)

$ rvm install 2.3
  • 1

错误1: 在安装ruby的时候, 可能会如下报错, 提示 Updating system[YourMacName] password required for ‘port -dv self update’, 如下: 
这里写图片描述

解决: 
进行更新:

$ sudo port self update

更新完成后, 如图: 
这里写图片描述

错误2: 
或者你可能遇到如下错误, 原因是需要安装Homebrew.

Error running 'requirements_osx_port_libs_install curl-ca-bundle automake libtool libyaml libffi libksba',
showing last 15 lines of /Users/acewill/.rvm/log/1468253599_ruby-2.3.0/package_install_curl-ca-bundle_automake_libtool_libyaml_libffi_libksba.log

这里写图片描述 
解决: 
参照stack overflow上的问题Installing RVM: “Requirements installation failed with status: 1.”

需要安装Homebrew , 通过以下命令:

ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"

重新安装ruby 

安装完成会显示这个:


$ ruby -v

2,安装cocoa pods
1.先升级Gem(可以省略)
    sudo gem update --system

2.切换cocoapods的数据源
    【先删除,再添加,查看】
    gem source --remove https://rubygems.org/
    gem source -a https://ruby.taobao.org/
    gem source -l

3.安装cocoa pods  (下边随便选一个就好了,选完了需要输入你的账户密码的)

 sudo gem install cocoapods
    或者(如10.11系统)sudo gem install -n /usr/local/bin cocoa pods
(当你可以再次输入的时候就需要配置仓库了)

4.设置pod仓库   
    pod setup

(上边这一步需要等很久了!!!!大约不到550M吧 看你网速了,一般3个小时左右吧,你可以看一下,这个仓库会在你个人文件夹下创建一个隐藏文件.cocoapods 所有的文件都下载这里边,用os系统你可以用空格的方法,或者右键点击查看文件夹的大小的方法来查看下载了多少,这样心里就有个数了... ...少年你可以出门去小卖部买干脆面了...)
5.测试
pod --version
如果有版本号,则说明已经安装成功

3、使用CocoaPods

a  新建一个项目,名字PodTest

 

b  终端中,cd到项目总目录(注意:包含PodTest文件夹、PodTest.xcodeproj、PodTestTest的那个总目录)

 

[objc] view plain copy
 
 
 在CODE上查看代码片派生到我的代码片
  1. cd /Users/lucky/Desktop/PodTest   

c  建立Podfile(配置文件)

 

接着上一步,终端输入 vim Podfile

 

键盘输入 i,进入编辑模式,输入

platform :ios, '7.0' 
pod 'MBProgressHUD', '~> 0.8'

 

然后按Esc,并且输入“ :”号进入vim命令模式,然后在冒号后边输入wq

 

注意:键盘输入 :后,才能输入wq。回车后发现PodTest项目总目录中多一个Podfile文件

 

激动人心的时刻到了:确定终端cd到项目总目录,然后输入 pod install,等待一会,大约3分钟。

 

 

查看项目根目录:

 

注意:现在打开项目不是点击 PodTest.xodeproj了,而是点击 PodTest.xcworkspace

 

对于工程发生的变化,有几点需要说明:

a、第三方库会以成静态库方式引入工程使用

 

CocoaPods会将所有的第三方库以target的方式组成一个名为Pods的工程,该工程就放在刚才新生成的Pods目录下。整个第三方库工程会生成一个名称为libPods.a的静态库提供给工程使用。

b、xcworkspace(PodTest.xcworkspace)的作用是管理工程和第三方库

 

PodTest工程和Pods工程被以workspace的形式组织和管理。


打开项目后看到项目结构并且测试一下:

 

运行结果:

 

补充:

1、CocoaPods的基本安装及使用都详细的说明了,但还有一些补充,当需要同时导入多个第三方时候怎么办 ?

这就需要修改Podfile了,就是用vim编辑的那个保存在项目根目录中的文件,修改完了Podfile文件,需要重新执行一次pod install命令。

例如:

 

platform :ios

pod 'JSONKit',       '~> 1.4'

pod 'AFNetworking',  '~> 2.0'

 

2、CocoaPods可以查找你想要的第三方库

终端输入命令:pod search UI

疯了了,我怎么查找这么大众的关键字,好多库~~

然后重新编辑Podfile文件,按照之前的步骤,把更多的库都导入项目!

3、上文中“建立Podfile(配置文件)接着上一步,终端输入 vim Podfile”步骤,如果不习惯使用vim编辑器,也可以使用linux命令touch,生成一个空的Podfile文件,然后使用其他的文本编辑器都可以,例如:

 

[objc] view plain copy
 
 
 在CODE上查看代码片派生到我的代码片
  1. lizhongfudeMacBook-Pro:~ lizhongfu$ cd /Users/lizhongfu/Desktop/TestProject   
  2. lizhongfudeMacBook-Pro:TestProject lizhongfu$ touch Podfile  
编辑好Podfile文件后,就可以执行pod install第三方导入了(详见:补充第1条),CocoaPods就开始为我们做下载源码、配置依赖关系、引入需要的framework等一些列工作。

 

4、如果已经生成了CocoaPods管理的工程,则可以在Xcode中编辑Podfile,编辑保存后,别忘记cd到根目录,调用pod install命令

5、项目存在多个Target的时候,需要配置Podfile文件来支持新增加的Target,否则只支持项目默认建立时生成的Target:

a、如果新建一个Target,命名为Second,并且Second与Test两个Target所需要的第三方支持相同,也就是使用相同的Pods依赖库,则可以使用

link_with关键字:

 

[objc] view plain copy
 
 
 在CODE上查看代码片派生到我的代码片
  1. link_with 'Test', 'Second'  
  2. platform :ios  
  3. platform :ios, ‘9.0’    
  4. pod 'AFNetworking', '~> 2.0'  

b、如果不同的Target需要不同的依赖库,则可以

 

[objc] view plain copy
 
 
 在CODE上查看代码片派生到我的代码片
  1. platform :ios  
  2. target :'Test' do  
  3. pod 'Reachability'  
  4. pod 'SBJson'     
  5. pod 'AFNetworking'   
  6. end    
  7.     
  8. target :'Second' do  
  9. pod 'OpenUDID'   
  10. end  


 

 

6、出现/Library/Ruby/Gems/2.0.0/gems/claide-0.8.1/lib/claide/command.rb:417:in `help!': [!] You cannot run CocoaPods as root. (CLAide::Help)

重新打开一个终端,然后pod install,不要sudo pod install。

7、如果$ pod install时候遇到:

Analyzing dependencies  
Fetching podspec for `UAAppReviewManager` from `..`  
[!] Unable to satisfy the following requirements:  
- `UAAppReviewManager (from `..`)` required by `Podfile`  

8、如果要移除Cocoapods,则可以:

 

a. 删除工程文件夹下的Podfile、Podfile.lock及Pods文件夹

b. 删除xcworkspace文件

c. 使用xcodeproj文件打开工程,删除Frameworks组下的Pods.xcconfig及libPods.a引用

d. 在工程设置中的Build Phases下删除Check Pods Manifest.lock及Copy Pods Resources

 

 

ps:如果将cocoapods集成到工程中后不小心修改或删除了其相关文件导致无法便以通过例如:不小心把

Pods.xcconfig给删除了然后出现diff: /../Podfile.lock: No such file or directory,用上面的方法删除cocoapods后,

再重新$sudo pod install一下就好了。

如果编译的时候出现权限问题,对工程文件夹$sudo chmod 777 path-to-project-folder/*

$sudo chown 777 path-to-project-folder/*


9、当库正常导入,但还是找不到相关头文件,则可以:

在TARGETS -> Search Paths -> User Header Search Paths 中 写入 ${SRCROOT}再将后面参数改为recursive:

 

10、Xcode - ld: library not found for -lPods

当新增加一个Target,并且pod install后,由于创建项目是默认创建的Target的Build Phases中引用了旧的.a,例如libPods.a,当新增加Targget后,libPods.a已经变成了libPods-Test.a,而新增加的Target名字为Second,依赖的.a为libPods-Second.a。所以libPods.a此时已经不再被引用,并且不会被生成,如果任何地方引用了就会报错,解决办法是出现问题的Target的Build Phases中删除无用的.a引用,例如libPods.a

11、pod update
若果Podfile中指定的依赖库版本不是写死的,当对应的依赖库有了更新,无论有没有Podfile.lock文件都会去获取Podfile文件描述的允许获取到的最新依赖库版本。

12、在引用第三方,如果想明确第三方版本号的时候,还有一些小细节:

 

[objc] view plain copy
 
 
 在CODE上查看代码片派生到我的代码片
  1. pod 'AFNetworking'      //不显式指定依赖库版本,表示每次都获取最新版本  (<span style="color: rgb(50, 62, 50); font-family: Arial; font-size: 14px; line-height: 26px;">11、</span><span style="color: rgb(50, 62, 50); font-family: Arial; font-size: 14px; line-height: 26px;">pod update</span>)  
  2. pod 'AFNetworking', '2.0'     //只使用2.0版本    
  3. pod 'AFNetworking', '> 2.0'     //使用高于2.0的版本    
  4. pod 'AFNetworking', '>= 2.0'     //使用大于或等于2.0的版本    
  5. pod 'AFNetworking', '< 2.0'     //使用小于2.0的版本    
  6. pod 'AFNetworking', '<= 2.0'     //使用小于或等于2.0的版本    
  7. pod 'AFNetworking', '~> 0.1.2'     //使用大于等于0.1.2但小于0.2的版本    
  8. pod 'AFNetworking', '~>0.1'     //使用大于等于0.1但小于1.0的版本    
  9. pod 'AFNetworking', '~>0'     //使用最新版本,与不显示指定依赖库版本相同  


巧大神这里有更多内容,其中介绍了pod制作及Podfile.lock的相关内容《用CocoaPods做iOS程序的依赖管理》

13、如果pod install之后,一直停留在Updating local specs repositories,可以试一试 pod install --verbose --no-repo-update,原因是pod install被墙了

 14、(2016年6月11日)The dependency 'xxx' is not used in any concrete target

在Podfile文件中需要明确指出使用第三方库的target,例如:

platform:ios,'7.0'
pod 'MJRefresh', '~> 3.1.0'
pod 'SDWebImage', '~> 3.7.6'
pod 'SVProgressHUD', '~> 2.0.3'
pod 'AFNetworking', '~> 3.1.0'

改为:

platform:ios,'7.0'
target "MyTarget" do
pod 'MJRefresh', '~> 3.1.0'
pod 'SDWebImage', '~> 3.7.6'
pod 'SVProgressHUD', '~> 2.0.3'
pod 'AFNetworking', '~> 3.1.0'
end

 

pod update 试了还可以用
pod install  被墙了,请大家换成pod install --verbose --no-repo-update

 

升级10.11后使用CocoaPod出现-bash: pod: command not found 解决办法

 

1.升级10.11后,运行pod命令出现:

-bash: pod: command not found

解决办法:

sudo gem install -n /usr/local/bin cocoapods
2'如果还不能解决,可以使用以下方法再试试:

sudo gem install -n /usr/local/bin cocoapods  /

sudo chmod +rx /usr/local/bin

 

3.遇到如下错误可能是因为装了多个Xcode导致路径变了

[!] Unable to add a source with url `https://github.com/CocoaPods/Specs.Git` named `master-1`.  You can try adding it manually in `~/.cocoapods/repos` or via `pod repo add`. 

解决办法:

sudo xcode-select -switch /Applications/Xcode.app

 /Applications/Xcode.app:此部分未Xcode所在路径,找到Xcode的安装路径,拖进来即可

4.

pod》error:The dependency `` is not used in any concrete target

我的原来Podfile的内容是:

platform:ios,'7.0'
pod 'MJRefresh', '~> 3.1.0'
pod 'SDWebImage', '~> 3.7.6'
pod 'SVProgressHUD', '~> 2.0.3'
pod 'AFNetworking', '~> 3.1.0'
修改为:
platform:ios,'7.0'
target "MyTarget" do
pod 'MJRefresh', '~> 3.1.0'
pod 'SDWebImage', '~> 3.7.6'
pod 'SVProgressHUD', '~> 2.0.3'
pod 'AFNetworking', '~> 3.1.0'
end
此处的MyTarget为自己的工程名

 

 


posted on 2016-10-12 10:57  冰棍超人  阅读(615)  评论(0)    收藏  举报

导航