1、全新安装前,先检查是否有安装残留linux
因为Mac 10.11更改了安全机制,因此cocoapods得安装和卸载命令也有所改变,ios
一、若是以前装过cocopods,最好先卸载掉,卸载命令:git
$ sudo gem uninstall cocoapods【Mac 10.10以前】github
$ sudo gem uninstall -n /usr/local/bin cocoapods【Mac 10.11以后】web
二、先查看本地安装过的cocopods相关东西【本步骤没有必要】,命令以下:sql
$ gem list --local | grep cocoapodsvim
会显示以下:xcode
cocoapods-core (0.39.0)安全
cocoapods-downloader (0.9.3)ruby
cocoapods-plugins (0.4.2)
cocoapods-search (0.1.0)
cocoapods-stats (0.6.2)
cocoapods-trunk (0.6.4)
cocoapods-try (0.5.1)
而后逐个删除吧:
$ sudo gem uninstall cocoapods-core【Mac 10.10以前】
$ sudo gem uninstall -n /usr/local/bin cocoapods-core【Mac 10.11以后】
。。。
2、安装
因为网上的教程基本都大同小异,但细节之处还不是很完善,因此借机会在这里补充下:
注:要使用CocoaPods,那就要下载安装它,而下载安装CocoaPods须要Ruby环境
一、准备工做
当前安装环境为Mac os 10.11.6。Mac OS自己自带Ruby,但仍是更新一下保险,由于我第一次安装在没有更新Ruby的状况下就失败了。
a) 查看下当前ruby版本:打开终端输入 ruby -v(确实安装了,不过用这个版本接下来工做失败了,因此更新下ruby)(更新方法本身百度。。。)
b)cocoapods镜像:https://gems.ruby-china.org/ 好像如今不支持淘宝了
终端输入以下命令(把Ruby镜像指向Ruby China,避免被墙,你懂得)
$gem sources --remove https://rubygems.org/
$gem sources --add https://gems.ruby-china.org/
$gem sources -l (用来检查使用替换镜像位置成功)
二、下载安装CocoaPods
终端输入:sudo gem install -n /usr/local/bin cocoapods
接下来进行安装,执行:
$ pod setup
Terminal会停留在 Setting up CocoaPods master repo 这个状态一段时间,是由于要进行下载安装,并且目录比较大,须要耐心等待一下.安装成功后,你会看到: setup completed
这样就下载安装好了CocoaPods
/************************************************************************************************************************************/
安装过程遇到的问题:
一、Ruby版本太低(更新就好了)
二、
三、
四、
解决方法:上面错误主要是os10.11+和cocoapods1.0+版本升级的安全机制更改形成的。主要出如今pod setup过程当中。且该过程等待时间很是长,因此,你能够在$sudo gem install -n /usr/local/bin cocoapods命令后直接执行$Git clone https://git.coding.net/CocoaPods/Specs.git ~/.cocoapods/repos/master 该过程做用与 pod setup做用相同,做者亲测。效果极佳!!!!
若是还不成功!!!!能够一样的方法安装正式版v0.39 而后在升级到v1.0版本
gem update --system
sudo gem install -n /usr/local/bin cocoapods --pre
/************************************************************************************************************************************/
3、使用CocoaPods
a 新建一个项目,名字PodTest
b 终端中,cd到项目总目录(注意:包含PodTest文件夹、PodTest.xcodeproj、PodTestTest的那个总目录)
c 创建Podfile(配置文件)
接着上一步,终端输入$vim Podfile
键盘输入 i,进入编辑模式,输入
platform :iOS, '8.0'
target "PodTest" do
pod 'MBProgressHUD', '~> 1.0.0'
end
而后按Esc,而且输入“ :”号进入vim命令模式,而后在冒号后边输入wq
注意:键盘输入 :后,才能输入wq。回车后发现PodTest项目总目录中多一个Podfile文件
激动人心的时刻到了:肯定终端cd到项目总目录,而后输入 $pod install,等待一会。
查看项目根目录:
注意:如今打开项目不是点击 PodTest.xodeproj了,而是点击 PodTest.xcworkspace
对于工程发生的变化,有几点须要说明:
a、第三方库会以成静态库方式引入工程使用
CocoaPods会将全部的第三方库以target的方式组成一个名为Pods的工程,该工程就放在刚才新生成的Pods目录下。整个第三方库工程会生成一个名称为libPods.a的静态库提供给工程使用。
b、xcworkspace(PodTest.xcworkspace)的做用是管理工程和第三方库
PodTest工程和Pods工程被以workspace的形式组织和管理。
补充:
一、CocoaPods的基本安装及使用都详细的说明了,但还有一些补充,当须要同时导入多个第三方时候怎么办 ?
这就须要修改Podfile了,就是用vim编辑的那个保存在项目根目录中的文件,修改完了Podfile文件,须要从新执行一次pod install命令。
例如:
platform :ios
pod 'JSONKit', '~> 1.4'
pod 'AFNetworking', '~> 2.0'
二、CocoaPods能够查找你想要的第三方库
终端输入命令:pod search JSONKit
疯了了,我怎么查找这么大众的关键字,好多库~~
而后从新编辑Podfile文件,按照以前的步骤,把更多的库都导入项目!
三、上文中“创建Podfile(配置文件)接着上一步,终端输入 vim Podfile”步骤,若是不习惯使用vim编辑器,也可使用linux命令touch,生成一个空的Podfile文件,而后使用其余的文本编辑器均可以,例如:
编辑好Podfile文件后,就能够执行pod install第三方导入了(详见:补充第1条),CocoaPods就开始为咱们作下载源码、配置依赖关系、引入须要的framework等一些列工做。
四、若是已经生成了CocoaPods管理的工程,则能够在Xcode中编辑Podfile,编辑保存后,别忘记cd到根目录,调用pod install命令
五、项目存在多个Target的时候,须要配置Podfile文件来支持新增长的Target,不然只支持项目默认创建时生成的Target:
a、若是新建一个Target,命名为Second,而且Second与Test两个Target所须要的第三方支持相同,也就是使用相同的Pods依赖库,则可使用
link_with关键字:
b、若是不一样的Target须要不一样的依赖库,则能够
六、出现/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。
七、若是$ pod install时候遇到:
Analyzing dependencies
Fetching podspec for `UAAppReviewManager` from `..`
[!] Unable to satisfy the following requirements:
- `UAAppReviewManager (from `..`)` required by `Podfile`
八、若是要移除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/*
九、当库正常导入,但仍是找不到相关头文件,则能够:
在TARGETS -> Search Paths -> User Header Search Paths 中 写入 ${SRCROOT}再将后面参数改成recursive:
十、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
十一、pod update
若果Podfile中指定的依赖库版本不是写死的,当对应的依赖库有了更新,不管有没有Podfile.lock文件都会去获取Podfile文件描述的容许获取到的最新依赖库版本。
十二、在引用第三方,若是想明确第三方版本号的时候,还有一些小细节:
1三、若是pod install以后,一直停留在Updating local specs repositories,能够试一试 pod install --verbose --no-repo-update,缘由是pod install被墙了
可能出现的错误:
1、pod install时报错:
一、终端报错:The dependency MBProgressHUD (~> 0.9.2)
is not used in any concrete target.
二、缘由:CocoaPods升级到最新版本(包括一些高版本),Podfile文件的内容必须明确指出所用第三方库的targetName.
三、报错分析:低版本和高版本写法不同.
低版本:
platform :ios, '8.0'
pod 'MBProgressHUD', '~> 0.9.2'
高版本:
platform :ios, '8.0'
target "targetName" do
pod 'MBProgressHUD', '~> 0.9.2'
end
注意:这里的 targetName 填写工程的名字。
2、删除某个框架
方法:
1.打开Podfile文件,删除JSONKit该行,即:
platform:ios, '7.0'
pod 'AFNetworking', '~> 2.1.0'pod 'JSONKit', '~> 1.5pre'(删除该行)
pod 'MBProgressHUD', '~> 0.8'
(若是想换成1.1版本,将被删除的行改为pod 'JSONKit-NoWarning', '~> 1.1'便可)