cocoaPods使用实践[合格]

第一篇,往xcode工程引入cocopods管理三方依赖
一,cocopods概述
cocopods是一个管理三方依赖的库或者插件,安卓一般使用mevan来管理依赖。
相对于传统的管理依赖的方式,首先传统的依赖管理暂时理解成:拖代码,引入.a静态库,等方式。cocopods管理依赖的原理是解析podfile文件,找到库列表,若库没有设定版本则拉取最新版本,若库没有自定义地址,则到github上去拉取对应的库。通过这种方式管理三方依赖能简化对依赖库的管理操作,并且第二个好处是可以轻松明了的去设定依赖的版本,第三个好处是当依赖库经常更新时只要执行一些pod update就可以拉到最新的依赖代码,还有很多好处,所以业界大家都在用cocopods进行依赖库的管理。cocopods的坏处当然也有,就是需要一点技术成本去了解熟悉使用这种技术,但是任何一种技术都是解决一方面问题而产生的,而对技术的学习也很大程度上是业务需要的需求。
cocopods实际上是把依赖库打成静态库然后导入pod工程,pod工程然后自己也打成一个静态库供.xcworkspace使用

二,cocopods安装
如果你的电脑可以科学上网,直接使用下面命令去安装cocopods
sudo gem install cocoapods

如果你发现等待了好久都没有任何反应,那么也不要紧啊,用非官方的方式来安装
先查看下pod的源是什么
gem sources -l
然后如果是下面这个就用下面的命令移除这个源
$ gem sources --remove https://rubygems.org/
//等有反应之后再敲入以下命令
$ gem sources -a https://ruby.taobao.org/
停止基于 HTTP 协议的镜像服务, 请在配置中使用 HTTPS 协议代替
现在换成这个了
gem sources --add https://gems.ruby-china.org/ --remove https://rubygems.org/

这个淘宝的镜像不知道是不是最新的,建议更新一下,使用下面命令,如果没有反应也可以不甩他。
sudo gem install cocoapods. 如果安装不上用这个命令安装:sudo gem install -n /usr/local/bin cocoapods

异常情况:(来自网上)
使用CocoaPods时遇到pod setup失败的解决办法(2016.8.12更新)
先说解决方案:
1.访问 https://github.com/CocoaPods/Specs,然后将Specs项目fork到自己的github账户上

  1. 下载GitHub Desktop, 然后clone Specs项目。
  2. 将clone的Specs项目的文件夹改名为master,然后拖到/Users/用户名/.cocoapods/repos目录下。
  3. 运行pod setup

三,cocopods在实际工程的使用
要让你的project支持cocopods,首先得建一个Podfile,命令行切到你的工程主目录,也就是git的主目录执行下面的命令。
➜ MyLeanCloud git:(master) ✗ touch Podfile

然后更改Podfile文件,给当前工程加上一些三方依赖库
➜ MyLeanCloud git:(master) ✗ vi Podfile //打开Podfile文件,然后输入i,接着command + v粘上下面的依赖
添加下面的内容
platform :ios, ‘7.0'
inhibit_all_warnings!

pod 'ASIHTTPRequest', :git => '[email protected]:_iOS/ThirdParty_ASIHTTPRequest'

pod 'OHAttributedLabel', '~> 3.5.3'

pod "AFNetworking", “2.0"
pod 'dyci', :git => 'https://github.com/DyCI/dyci-main.git'

最后,执行下面命令安装pod,
pod install

成功后你的工程就会多出来几个文件,以后打开工程不是打开XXXXX.xcodeproj,而是打开XXXXX.xcworkspace.
注意到你的工程中有个pod,可以找到刚才设置的依赖的代码。

以后若pod里面的依赖库有更新,使用
pod update

第二篇,自制cocopods依赖库

一,在github上建立仓库

二,写myLib.podspec 文件。该文件是 cocopods的描述文件,名称自定义。写法如下
pod spec create myLib
这个命令创建一个.podspec模板文件,里面有几个地方需要自己填充下,填充之后,去掉注释之后就是下面的模样了,下面是一个验证通过的.podspec
Pod::Spec.new do |s|
s.name = "myLib"
s.version = "0.0.1"
s.summary = "mylib is a lib that help user post message."
s.description = <<-DESC
A longer description of myLib in Markdown format.
DESC
s.homepage = "https://github.com/wangzz/WZMarqueeView"
s.license = "MIT"
s.author = { "刘建中" => "[email protected]" }
s.source = { :git => "https://github.com/wangzz/WZMarqueeView.git", :tag => s.version }
s.platform = :ios, "5.0"
s.ios.deployment_target = "5.0"
s.requires_arc = true
s.source_files = 'MyLeanCloud/*'
s.frameworks = 'Foundation', 'CoreGraphics', 'UIKit'
end

三,所有依赖库都要有LICENSE文件,你必须添加一个LICENSE文件才能在cocopods中被广大用户依赖,下面有个专业的LICENSE文件模板

The MIT License (MIT)

Copyright (c) 2014 刘建中

Permission is hereby granted, free of charge, to any person obtaining a copy of
this software and associated documentation files (the "Software"), to deal in
the Software without restriction, including without limitation the rights to
use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
the Software, and to permit persons to whom the Software is furnished to do so,
subject to the following conditions:

The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

四,所有cocopods依赖库都要统一提交到cocopods的仓库才能供别人使用,提交前要检查下是否能验证通过,方法如下:
set the new version to 1.0.0
set the new tag to 1.0.0
给仓库当前版本打上tag,并设置版本,这个在使用依赖库时对应代码的版本
pod lib lint 检查.podspec是否能够通过审核
git add .
git push …
提交代码到git上
五,最后一步,把我们的代码提交到https://github.com/CocoaPods/Specs,也就是cocopods的git官方仓库
操作,首先fork一份specs代码到我们的git上,然后clone代码到本地
然后在Specs目录下新建myLib目录,在myLib目录下新建版本号命名的文件夹0.0.1,然后在0.0.1目录下放上刚才新建的myLib.podspec文件
如果后期版本是0.0.2,需要在在0.0.1同级目录新建0.0.2目录,放上0.0.2对应的myLib.podspec文件就行了

然后把代码提交到我们fork的那个仓库,最后给cocopods提一个pullrequest,如果通过了,我们的的依赖库就可以被别人使用了。

你可能感兴趣的:(cocoaPods使用实践[合格])