安装
- 安装Ruby
CocoaPods基于Ruby语言开发而成,因此安装CocoaPods前需要安装Ruby环境。幸运的是Mac系统默认自带Ruby环境,如果没有请自行查找安装。检测是否安装Ruby:$ gem -v2.0.14
安装则会提示当前Ruby版本。gem介绍:gem是一个管理Ruby库和程序的标准包,它通过Ruby Gem(如 http://rubygems.org/ )源来查找、安装、升级和卸载软件包,非常的便捷。
- 更换gem源
因为国内网络的问题导致gem源间歇性中断,原因你懂的。因此我们需要更换gem源,使用淘宝的gem源[https://ruby.taobao.org/.](https://ruby.taobao.org/%E3%80%82)
第一步:移除默认的源gem sources --remove https://rubygems.org/
第二步:指定淘宝的源gem sources -a https://ruby.taobao.org/
第三步:查看指定的源是不是淘宝源$ gem sources -l
*** CURRENT SOURCES ***
https://ruby.taobao.org/
如果是https://ruby.taobao.org/,则更换成功。
- 安装CocoaPods
改成淘宝源后执行以下命令进行安装:sudo gem install cocoapods
如果换成国内镜像使用 gem install cocoapods 报错:ERROR: While executing gem ... (Gem::DependencyError)
Unable to resolve dependencies: cocoapods requires cocoapods-core (= 1.1.1), cocoapods-downloader (< 2.0, >= 1.1.2), cocoapods-trunk (< 2.0, >= 1.1.1), xcodeproj (< 2.0, >= 1.3.3)
执行:sudo gem update --system && sudo gem install cocoapods
报错:ERROR: While executing gem ... (Errno::EPERM)
Operation not permitted - /usr/bin/xcodeproj
执行:sudo gem install -n /usr/local/bin cocoapods
安装完成,输入以下命令检测是否安装成功:$ pod --version
1.1.1
cd到自己的项目目录下
创建Podfilevim Podfile
如果没有创建Podfile
文件将无法安装, CocoaPods都不知道改安装说明, 怎么去安装呢, 对吧.[!] No `Podfile‘ found in the project directory.
输入以下代码(配置文件,需要添加的第三方):
source ‘https://github.com/CocoaPods/Specs.git‘
platform :ios, ‘8.0‘
inhibit_all_warnings!
target ‘工程名‘ do
pod ‘AFNetworking‘, ‘~> 2.6.0‘
end
然后保存退出
esc:wq
执行pod update
OR pod install
。
如果报错:
[!] Unable to add a source with url `https://github.com/CocoaPods/Specs.git` named `master`.
You can try adding it manually in `~/.cocoapods/repos` or via `pod repo add`.
执行:sudo xcode-select -switch /Applications/Xcode.app/Contents/Developer
(xcode目录)
问题描述
1:[!] The ‘master‘ repo requires CocoaPods 1.0.0 - (currently using 0.39.0) Update CocoaPods, or checkout the appropriate tag in the repo.
问题原因:没有更新到最新cocoapods版本
sudo gem install -n /usr/local/bin cocoapods –pre
如果报错或其他问题
sudo gem update --system && sudo gem install cocoapods
出现报错信息: ERROR: While executing gem ... (Errno::EPERM)
Operation not permitted - /usr/bin/xcodeproj
执行: sudo gem install -n /usr/local/bin cocoapods
输入以下命令检测是否成功: pod --version
1.1.1
2:[!] The dependency `AFNetworking (~> 2.6.0)` is not used in any concrete target.
等
问题原因:podfile升级到最新版本,pod里的内容必须明确指出所用第三方库的target
可以修改Podfile文件的配置文件,让它兼容不指定固定版本;且又不报错
platform :ios, ‘8.0‘
inhibit_all_warnings!
target ‘工程名‘ do
pod ‘AFNetworking‘, ‘~> 2.6.0‘
end
3:Updating local specs repositories
遇到pod install或者pod update长时间卡在Updating local specs repositories
- 常见的解决方式是跳过更新cocoapods的spec仓库
pod install --verbose --no-repo-update
pod update --verbose --no-repo-update
- 最好的办法是
pod repo remove master
pod setup
pod install
4:[!]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编辑,或者使用终端敲命令去编辑。或者输入格式错误,没输入运行版本:$platform:ios, ‘8.0‘
5:使用cocoapods导入第三方类库后头文件没有代码提示?
选择Target -> Build Settings 菜单,找到\”User Header Search Paths\”设置项,新增一个值"${SRCROOT}",并且选择\”Recursive\”
6:[!]Unable to find a target named ‘ ‘;
Podfile的工程文件和建立工程名不一致。名字改为一致即可
7:syntax error ,unexpected end-of-input,expecting keyword_end
podfile写法有问题,使用标准的podfile的写法
platform :ios, ‘8.0‘
inhibit_all_warnings!
target ‘工程名‘ do
pod ‘AFNetworking‘, ‘~> 2.6.0‘
end
8: Analyzing dependencies
[!]Could not automatically select an Xcode project . Specify one in your Podfile like 50 : xcodeproj ‘ path / to / Project . xcodeproj
自己建立了一个空文件夹,没有建立工程
处理方法:删除这个空工程,重新建立一个工程,再按照上面知识点讲解一步步来即可。
9:pod 导入后出现"_OBJC_CLASS_$_xxx"
target->build phases->link binary with libraries添加xxx.a
如果不是pod导入的类库,出现这种问题
原因:在创建类的时候没有勾选"add to targets"
target->build phases->compile sources 添加.h,.m文件
或(建议用上面)
在Build Setting 中的Other Linker Flags选项中加入$(OTHER_LDFLAGS)
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
target->build phases->link binary with libraries
11:pod 导入库,找不到头文件
在TARGETS -> Search Paths -> User Header Search Paths 中 写入 ${SRCROOT}再将后面参数改为recursive:
12:如果要移除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
不小心删除pods.xcconfig,出现diff: /../Podfile.lock: No such file or directory
sudo pod install一下就好了
如果编译的时候出现权限问题,对工程文件夹$sudo chmod 777 path-to-project-folder/*
$sudo chown 777 path-to-project-folder/*
13:出现/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。
14:删除CocoaPods版本,并安装指定版本
比如我本来安装完CocoaPods 1.0.0版,但发现它实现跟先前还是差别满大的,决定降回0.39这个比较稳定版本;就可以用命令先删除本地的CocoaPods版本,再指定安装特定版本;
a 卸载 cocoapods(它会提示你要删除本地哪个版也可以全删)
sudo gem uninstall cocoapods
b 安装 0.39版本
sudo gem install -n /usr/local/bin cocoapods -v 0.39
15:更新 CocoaPods 或者以前手动添加过第三方SDK改用Cocopods,可能会出现以下的错误
错误1:
[!] The `Paopao [Debug]` target overrides the `PODS_ROOT` build setting defined in `Pods/Target Support Files/Pods/Pods.debug.xcconfig‘. This can lead to problems with the CocoaPods installation
- Use the `$(inherited)` flag, or
- Remove the build settings from the target.
[!] The `Paopao [Debug]` target overrides the `OTHER_LDFLAGS` build setting defined in `Pods/Target Support Files/Pods/Pods.debug.xcconfig‘. This can lead to problems with the CocoaPods installation
- Use the `$(inherited)` flag, or
- Remove the build settings from the target.
[!] The `Paopao [Release]` target overrides the `PODS_ROOT` build setting defined in `Pods/Target Support Files/Pods/Pods.release.xcconfig‘. This can lead to problems with the CocoaPods installation
- Use the `$(inherited)` flag, or
- Remove the build settings from the target.
[!] The `Paopao [Release]` target overrides the `OTHER_LDFLAGS` build setting defined in `Pods/Target Support Files/Pods/Pods.release.xcconfig‘. This can lead to problems with the CocoaPods installation
- Use the `$(inherited)` flag, or
- Remove the build settings from the target.
产生此警告的原因是项目 Target 中的一些设置,CocoaPods 也做了默认的设置,如果两个设置结果不一致,就会造成问题。
我想要使用 CocoaPods 中的设置,分别在我的项目中定义PODS_ROOT
和 Other Linker Flags
的地方,把他们的值用$(inherited)
替换掉,进入终端,执行
pod update
警告没了
一种简单粗暴的方法:
点击项目文件 project.xcodeproj,右键显示包内容
,用文本编辑器打开project.pbxproj
,删除OTHER_LDFLAGS
的地方,保存,pod update
,警告没了。。。。
16:
17: