CocoaPods安装使用心得,分享给墙内的朋友们

前言##

CocoaPods是一个负责管理iOS项目中第三方开源代码的工具。

二、安装
由于网上的教程基本都大同小异,但细节之处还不是很完善,所以借机会在这里补充下:
注:要使用CocoaPods,那就要下载安装它,而下载安装CocoaPods需要Ruby环境

1.Ruby环境搭建##

当前安装环境为Mac Pro 10.11.1。Mac OS本身自带Ruby,但还是更新一下保险,因为升级了系统之后,可能会出现一些意想不到的情况,最好还是更新一下Ruby。

  • 查看下当前ruby版本:打开终端输入 ruby -v(确实安装了,不过iOS9使用https协议替换http协议,所以以前挂靠在淘宝下ruby的源的路径也要修改下,顺便更新下ruby)
CYdediannao:~ lcy$  ruby -v 
ruby 2.0.0p645 (2015-04-13 revision 50299) [universal.x86_64-darwin15]
  • 淘宝已经停止基于 HTTP 协议的镜像服务, 请在配置中使用 HTTPS 协议代替
CYdediannao:~ lcy$ gem sources - l
*** CURRENT SOURCES ***
http://ruby.taobao.org/
CYdediannao:~ lcy$ gem sources --add https://ruby.taobao.org/ --remove http://ruby.taobao.org/

https://ruby.taobao.org/ added to sources
http://ruby.taobao.org/ removed from sources
  • gem sources -l (用来检查使用替换镜像位置成功,然后升级ruby
CYdediannao:~ lcy$ sudo gem install rails

或者是

CYdediannao:~ lcy$ sudo gem update --system

2.下载安装CocoaPods

CYdediannao:~ lcy$ sudo gem install cocoapods 

出现的错误###:原因是该文件夹没有修改的权限

CYdediannao:~ lcy$ sudo gem install cocoapods 
Fetching: nap-1.0.0.gem (100%)
Successfully installed nap-1.0.0
Fetching: molinillo-0.4.0.gem (100%)
Successfully installed molinillo-0.4.0
Fetching: cocoapods-trunk-0.6.4.gem (100%)
Successfully installed cocoapods-trunk-0.6.4
Fetching: cocoapods-try-0.5.1.gem (100%)
Successfully installed cocoapods-try-0.5.1
Fetching: cocoapods-stats-0.6.2.gem (100%)
Successfully installed cocoapods-stats-0.6.2
Fetching: cocoapods-search-0.1.0.gem (100%)
Successfully installed cocoapods-search-0.1.0
Fetching: cocoapods-downloader-0.9.3.gem (100%)
Successfully installed cocoapods-downloader-0.9.3
Fetching: xcodeproj-0.28.2.gem (100%)
ERROR:  While executing gem ... (Errno::EPERM)
    Operation not permitted - /usr/bin/xcodeproj
10.11以上系统使用命令: sudo gem install -n /usr/local/bin cocoapods
CYdediannao:~ lcy$ sudo gem install -n /usr/local/bin cocoapods
Password:
Successfully installed xcodeproj-0.28.2
Fetching: cocoapods-core-0.39.0.gem (100%)
Successfully installed cocoapods-core-0.39.0
Fetching: cocoapods-0.39.0.gem (100%)
Successfully installed cocoapods-0.39.0
Parsing documentation for xcodeproj-0.28.2
Installing ri documentation for xcodeproj-0.28.2
Parsing documentation for cocoapods-core-0.39.0
Installing ri documentation for cocoapods-core-0.39.0
Parsing documentation for cocoapods-0.39.0
Installing ri documentation for cocoapods-0.39.0
3 gems installed

3.使用命令 pod search AFNetworking 查找某一个库,看cocoapods有没有安装好,搜索结果如下,已经安装好了cocoa pods


-> AFNetworking (2.6.0)
   A delightful iOS and OS X networking framework.
   pod 'AFNetworking', '~> 2.6.0'
   - Homepage: https://github.com/AFNetworking/AFNetworking
   - Source:   https://github.com/AFNetworking/AFNetworking.git
   - Versions: 2.6.0, 2.5.4, 2.5.3, 2.5.2, 2.5.1, 2.5.0, 2.4.1, 2.4.0, 2.3.1,
   2.3.0, 2.2.4, 2.2.3, 2.2.2, 2.2.1, 2.2.0, 2.1.0, 2.0.3, 2.0.2, 2.0.1, 2.0.0,
   2.0.0-RC3, 2.0.0-RC2, 2.0.0-RC1, 1.3.4, 1.3.3, 1.3.2, 1.3.1, 1.3.0, 1.2.1,
   1.2.0, 1.1.0, 1.0.1, 1.0, 1.0RC3, 1.0RC2, 1.0RC1, 0.10.1, 0.10.0, 0.9.2,
   0.9.1, 0.9.0, 0.7.0, 0.5.1 [master repo] - 2.6.0, 2.5.4, 2.5.3, 2.5.2, 2.5.1,
   2.5.0, 2.4.1, 2.4.0, 2.3.1, 2.3.0, 2.2.4, 2.2.3, 2.2.2, 2.2.1, 2.2.0, 2.1.0,
   2.0.3, 2.0.2, 2.0.1, 2.0.0, 2.0.0-RC3, 2.0.0-RC2, 2.0.0-RC1, 1.3.4, 1.3.3,
   1.3.2, 1.3.1, 1.3.0, 1.2.1, 1.2.0, 1.1.0, 1.0.1, 1.0, 1.0RC3, 1.0RC2, 1.0RC1,
   0.10.1, 0.10.0, 0.9.2, 0.9.1, 0.9.0, 0.7.0, 0.5.1 [master-1 repo]
   - Subspecs:
     - AFNetworking/Serialization (2.6.0)
     - AFNetworking/Security (2.6.0)
     - AFNetworking/Reachability (2.6.0)
     - AFNetworking/NSURLConnection (2.6.0)
     - AFNetworking/NSURLSession (2.6.0)
     - AFNetworking/UIKit (2.6.0)


-> AFNetworking+AutoRetry (0.0.5)
   Auto Retries for AFNetworking requests
   pod 'AFNetworking+AutoRetry', '~> 0.0.5'
   - Homepage: https://github.com/shaioz/AFNetworking-AutoRetry
   - Source:   https://github.com/shaioz/AFNetworking-AutoRetry.git
   - Versions: 0.0.5, 0.0.4, 0.0.3, 0.0.2, 0.0.1 [master repo] - 0.0.5, 0.0.4,
   0.0.3, 0.0.2, 0.0.1 [master-1 repo]


-> AFNetworking+Ext (1.2.1)
   AFNetworking的封装, 并提供一个 UIImageView+DYLoading  cache in fileSystem+memory
   pod 'AFNetworking+Ext', '~> 1.2.1'
   - Homepage: https://github.com/junhaiyang/AFNetworkingExt
   - Source:   https://github.com/junhaiyang/AFNetworkingExt.git
   - Versions: 1.2.1, 1.2, 1.1, 1.0, 0.5, 0.4, 0.3 [master repo] - 1.2.1, 1.2,
   1.1, 1.0, 0.5, 0.4, 0.3 [master-1 repo]
   - Subspecs:
     - AFNetworking+Ext/Base (1.2.1)
     - AFNetworking+Ext/AFCustomRequestOperation (1.2.1)
     - AFNetworking+Ext/AFDownloadRequestOperation (1.2.1)
     - AFNetworking+Ext/AFTextResponseSerializer (1.2.1)
     - AFNetworking+Ext/example (1.2.1)
     - AFNetworking+Ext/UIKit (1.2.1)
     - AFNetworking+Ext/UIKit/UIImageView+DYLoading (1.2.1)

##还有很大篇幅的结果,此处省略。。。##

4.cocoapods的使用

  • 新建一个项目,名字podsTest


    项目podsTest.png
  • 打开项目所在的文件夹,在终端敲入 cd 将文件夹拖拽到终端 或者用cd打开项目所在文件夹(注意:包含podsTest文件夹、podsTest.xcodeproj、podsTestTest、podsTestUITests的那个总目录)如图:

项目组织目录.png
进入到podsTest组织目录.png
  • 建立Podfile(配置文件)
    1.接着上一步,终端输入 vim Podfile


    屏幕快照 2015-10-23 16.09.45.png

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


    进入编辑模式.png

3.1 cocoaPods是1.0.0及以上版本,Podfile文件内容按这个格式输入

platform :ios, '8.0'
#use_frameworks!

target 'MyApp' do
pod 'AFNetworking', '~> 2.6'
pod 'ORStackView', '~> 3.0'
pod 'DACircularProgress', '~> 1.2.1'
pod 'HPGrowingTextView', '~> 1.1'
pod 'SCLAlertView-Objective-C', '~> 0.7.5'
pod 'MWPhotoBrowser', '~> 1.4.1'
pod 'Masonry', '~> 0.6.3'
pod 'MMMarkdown', '~> 0.5'
end

注意:里面的 MyApp 记得替换为自己工程里面的target。执行pod install / pod update 都可以。(#use_frameworks! 这个是个别需要用到它,比如reactiveCocoa,如果不需要用到的话,可以把我上面的代码中的这一行#use_frameworks!【删除】)

3.2 如果cocoaPods是1.0.0以下版本,Podfile文件内容按这个格式输入

platform :ios, '7.0'  
pod 'MBProgressHUD', '~> 0.9.1'
pod 'ASIHTTPRequest', '~> 1.8.2'
pod 'SDWebImage', '~> 3.7.3'

注意: 如果你不知道这些框架目前的版本是,可以使用命令pod search +框架名称查看 相应的信息

查找结果.png

4.然后按Esc,并且输入 shift +“ :”号进入vim命令模式,然后在冒号后边输入wq 按回车键,保存并且退出。
5.结果如下图:

编辑结果.png

6.发现podTest项目总目录中多一个Podfile文件

Podfile.png

7.激动人心的时刻到了:确定终端cd到项目总目录,然后输入 pod install,等待一会,框架安装好了如图所示,多出了3个文件夹/文件夹。

安装后的文件结构.png

注意:###

现在打开项目不是点击 podTest.xodeproj了,而是点击 podsTest.xcworkspace

屏幕快照 2015-10-23 16.45.00.png

5.cocoaPods使用心得

  • 最近使用CocoaPods来添加第三方类库,无论是执行pod install还是pod update都卡在了Analyzing dependencies不动 原因在于当执行以上两个命令的时候会升级CocoaPods的spec仓库,加一个参数可以省略这一步,命令如下:
pod install --verbose --no-repo-update 
pod update --verbose --no-repo-update

$ pod install只会按照Podfile的要求来请求类库,如果类库版本号有变化,那么将获取失败。但是 $ pod update会更新所有的类库,获取最新版本的类库。每次用$ pod update就行。

如果类库没有更新到最新版本的话,那么就需要修改Podfile文件中类库的版本号了
  • 安装一个xcode插件管理工具,地址 目前还不支持XCode7
    在终端中执行
curl -fsSL https://raw.github.com/supermarin/Alcatraz/master/Scripts/install.sh | sh  

安装完了打开xcode->window->package manger 搜cocoapods安装,方便操作。

  • 工程在模拟器上编译报错,不支持i386,Cocoapods确实还不支持64位模拟器,解决办法:
    其实就2条:
    1.build active architecture only 在debug的时候设置成YES,不要在release的时候用模拟器
    2.other linker flags 加一个 $(inherited)

  • 用到svn,git多人协作的话,Pods/这个文件夹不要上传,例如:
    .../Pods/Pods.xcodeproj ...Pods/Target Support Files/这些每次编译都会改动从而引起合并代码的时候冲突

心得内容来源

6.cocoaPods使用常见错误汇总:

  • pod install 时出现以下错误,错误原因是在vim Podfile 时,输入命令前面带有空格导致的,把空格去掉就好了
错误写法:
 platform :ios, '7.0'
 pod 'MBProgressHUD', '~> 0.9.1'
 pod 'ASIHTTPRequest', '~> 1.8.2'
 pod 'SDWebImage', '~> 3.7.3'
提示错误:
[!] Invalid `Podfile` file: undefined method ` pod' for #<Pod::Podfile:0x007ff3f9a45a48>. Updating CocoaPods might fix the issue.

正确写法:命令前面不留空格
platform :ios, '7.0'
pod 'MBProgressHUD', '~> 0.9.1'
pod 'ASIHTTPRequest', '~> 1.8.2'
pod 'SDWebImage', '~> 3.7.3'

7 使用CocoaPods来管理Objective-c的类库,非常方便。但是有一个小问题,当我在xcode输入import关键字的时候,没有自动联想补齐代码的功能,需要手工敲全了文件名,难以适应。
在stackoverflow上找到了解决办法:
1.Go to the Target > \”Build Settings\” tab and find the \”User Header Search Paths\” setting.
2.Set this to \”$(BUILT_PRODUCTS_DIR)\” and check the \”Recursive\” check box.
Now the built target will search the workspace’s shared build directory to locate the linkable header files.

简单说就是这么几步:
1.选择Target -> Build Settings 菜单,找到\”User Header Search Paths\”设置项
2.新增一个值$(BUILT_PRODUCTS_DIR),并且选择\”Recursive\”,这样xcode就会在项目目录中递归搜索文件
自动补齐功能马上就好使了。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,294评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,780评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,001评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,593评论 1 289
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,687评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,679评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,667评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,426评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,872评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,180评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,346评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,019评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,658评论 3 323
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,268评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,495评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,275评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,207评论 2 352

推荐阅读更多精彩内容