CocoaPods是什么?
当你开发iOS应用时,会经常使用到很多第三方开源类库,比如JSONKit,AFNetWorking等等。可能某个类库又用到其他类库,所以要使用它,手动一个个去下载所需类库十分麻烦。另外一种常见情况是,你项目中用到的类库有更新,你必须得重新下载新版本,重新加入到项目中,十分麻烦。所以,你需要 CocoaPods。
CocoaPods应该是iOS最常用最有名的类库管理工具了,上述两个烦人的问题,通过cocoaPods,只需要一行命令就可以完全解决,当然前提是你必须正确设置它。重要的是,绝大部分有名的开源类库,都支持CocoaPods。所以,作为iOS程序员的我们,掌握CocoaPods的使用是必不可少的基本技能了。
如何下载和安装CocoaPods?
在安装CocoaPods之前,首先要在本地安装好Ruby环境。
参考如何快速正确的安装 Ruby, Rails 运行环境
http://ruby-china.org/wiki/install_ruby_guide
下面提供一个快捷方法安装CocoaPods:
.访问 https://github.com/CocoaPods/Specs,然后将Specs项目fork到自己的github账户上
. 下载GitHub Desktop, 然后clone Specs项目。
. 将clone的Specs项目的文件夹改名为master,然后拖到/Users/用户名/.cocoapods/repos目录下。
. 运行pod setup
解释:pod setup的本质就是将https://github.com/CocoaPods/Specs上的Specs项目clone到/Users/用户名/.cocoapods/repos目录下。若此目录下已有Specs项目,则会将项目更新到最新的状态。由于Specs很大,容易导致pod setup失败。这时就需要我们手动安装Specs。若直接从github上下载zip文件,由于缺少git文件,会导致cocoa pods不使用。若用git clone,由于文件过大,容易导致失败。但是使用GitHub Desktop软件,则会提高clone的成功率,并且会给出clone的进度。
使用cocoapods:
利用CocoaPods,在项目中导入AFNetworking类库
.AFNetworking类库在GitHub地址是:https://github.com/AFNetworking/AFNetworking
为了确定AFNetworking是否支持CocoaPods,可以用CocoaPods的搜索功能验证一下。在终端中输入:
$ pod search AFNetworking
过几秒钟之后,你会在终端中看到关于AFNetworking类库的一些信息。
.使用Xcode 创建一个项目
打开终端,输入cd /Users/paladinfeng/Desktop/shareSDKDemo/demo
(注:cd后边有个空格,然后接你刚创建的项目的路径就可以了,别告诉我你不会直接拖进去)
创建这个PodFile后在终端中进入(cd命令)你项目所在目录,然后在当前目录下,利用vim创建Podfile,运行:
vim Podfile
.写入以下内容并保存 小提示:(终端vim文件 按 i 可编辑 ,esc 退出编辑,:wq 可保存退出)
platform :ios, '8.0'
target “target名称” do
pod 'AFNetworking', '~> 3.1.0'
end
CocoaPods报错:The dependency `AFNetworking ` is not used in any concrete target
请点击进去参考:
报错误[!] Pods written in Swift can only be integrated as frameworks; add `use_frameworks!` to your Podfil请点进去参考:
可能是要添加的这个库 不支持swift导致
解决办法:在podfile里面添加 use_frameworks!
platform:ios,'8.0'
#use_frameworks!个别需要用到它,比如reactiveCocoa MyApp为你的项目的名字
defpods
pod'AFNetworking','~>2.6'
pod'ORStackView','~>3.0'
pod'SwiftyJSON','~>2.3'
use_frameworks! //在这里添加,设置支持swift,如果不引进swift相关的类则可以不用写
end
target'MyApp'do
pods
end
就是在加入你需要的那些库之后最后再加一句use_frameworks!
.导入第三方库
$pod install
pod install与pod update区别:
1.使用pod install来安装新的库,即使你的工程里面已经有了Podfile,并且已经执行过pod install命令了;所以即使你是添加或移除库,都应该使用pod install。
2.使用pod update [PODNAME] 只有在你需要更新库到更新的版本时候用。
ps
当使用pod update遇到 ld: library not found for -ljcore-ios-1.1.1 可以这样解决
小技巧:
最近使用CocoaPods来添加第三方类库,无论是执行pod install还是pod update都卡在了Analyzing dependencies不动
原因在于当执行以上两个命令的时候会升级CocoaPods的spec仓库,加一个参数可以省略这一步,然后速度就会提升不少。加参数的命令如下:
pod install --verbose --no-repo-update
pod update --verbose --no-repo-update
至此,添加已经完成。可以看到项目目录里面多了4个文件,以后运行工程都使用.xcworkspace文件,而不再用.xcodeproj了。
查看 pod
版本:
$ pod --version
0.39.0
移除CocoaPods项目中已经配置的类库
.打开终端,输入cd /Users/paladinfeng/Desktop/shareSDKDemo/demo
(注:cd后边有个空格,然后接你创建的项目的路径就可以了,别告诉我你不会直接拖进去)
创建这个PodFile后在终端中进入(cd命令)你项目所在目录,然后在当前目录下,利用vim创建Podfile,运行:
vim Podfile
.看到以下内容并保存 小提示:(终端vim文件 按 i 可编辑 ,esc 退出编辑,:wq 可保存退出)
platform :ios, '8.0'
target “target名称” do
pod 'AFNetworking', '~> 3.1.0'(把这一行删掉)
end
.$pod install
编译运行没有错误完成
备注:
解决MAC系统升级(10.15)导致COCOAPODS失效问题
pod install 报错 sudo gem update --system 也不行
dunkhomedeMacBook-Pro:get dunkhome$ pod install
-bash: /usr/local/bin/pod: /System/Library/Frameworks/Ruby.framework/Versions/2.3/usr/bin/ruby: bad interpreter: No such file or directory
dunkhomedeMacBook-Pro:get dunkhome$ sudo gem update --system
ERROR: While executing gem ... (Gem::RemoteFetcher::FetchError)
bad response Not Found 404 (https://gems.ruby-china.org/specs.4.8.gz)
居然是404,于是我用浏览器打开https://gems.ruby-china.org,发现其服务域名更换了:
然后删除gem源:
gem sources --remove https://gems.ruby-china.org/
修改gem源:
gem sources -a https://gems.ruby-china.com
查看gem源是否是最新的:
gem sources -l
升级cocoapods:
sudo gem install -n /usr/local/bin cocoapods --pre
查看升级后的cocoapods版本:
pod --version
现在最新的是
MacBook-Pro:get dunkhome$ pod --version
1.8.3
Cocoapods - pod install 成功后找不到头文件解决
问题描述:使用Cocoapods时,import 找不到头文件。
问题原因:这是因为还没设置头文件的目录。
解决办法:在项目的Target的里设置一下,添加cocoapods头文件目录:目录路径直接写:${SRCROOT} ,后边选择recursive 。就可以了。
注意:是在 User Header Search Paths 里添加,不是上面的 Header Search Paths.
cocoapods
移除某一个框架以后,会遇到ld: library not found for -lxxxx-ios-x.x.x
这种情况下是因为将框架移除之后,并没有移除build setting
->other linker flag
中的引用,找到移除之后的框架,删除引用即可。