2020-12-25

cocoapod私有库创建管理与使用(一)

环境准备

  • 本地已安装好最新的cocoapods环境
  • xcode和mac os系统已是最新版本
  • 已申请gitee账号

参考资料

Publish Your Pods on CocoaPods with Trunk

cocoaPods 私有仓库的创建和使用

iOS-使用CocoaPods创建私有仓库(一)

感谢上面三位作者编写的博客支持我完成cocoapod私有库创建管理与使用这篇博客的编写。

一、创建远程pod仓库

  1. 首先我们需要准备一个空白的远程git仓库, 我们在gitee上创建一个名为HFMessage的空白代码仓库


    在这里插入图片描述
  2. 创建一个远程的pod仓库, 执行下列命令

pod repo add HFMessage https://gitee.com/panyongjie/HFMessage.git

image

执行命令后,会将远程仓库下载到本地硬盘上,本地目录的地址是/Users/用户名/.cocoapods/repos

在这里插入图片描述

进入本地磁盘进行查看


在这里插入图片描述
在这里插入图片描述

二、创建本地pod lib仓库

执行pod lib create 仓库名称

pod lib create HFMessage

在这里插入图片描述

创建成功后的目录如下


在这里插入图片描述

进入Example文件夹下执行pod install,然后运行项目到模拟器上。不执行pod install 直接运行模拟器会出现下列的错误 ERROR | [iOS] unknown: Encountered an unknown error (Could not find aiossimulator (valid values:)

三、Pod lib仓库版本管理

1.修改Spec配置文件

对spec文件进行如下修改


在这里插入图片描述

2.检查Spec配置文件

在podspec文件统计目录下执行下列命令

pod lib lint HFMessage.podspec --use-libraries --allow-warnings --verbose

配置正确的情况下可以看到如下输出


在这里插入图片描述

3.添加源代码并上传到git服务器

添加源代码到项目中


在这里插入图片描述
在这里插入图片描述

执行下面的命令将代码提交到远程服务器

git init
git add .
git commit -m “提交日志”
# 这里的tag必须和spec中的s.version中的内容一致,如果不添加tag,
# 进行pod repo push时会发生remote 错误
git tag ‘0.1.0’ 
# 添加远程服务器地址,这里不能有多余的空格,否则执行命令会提示格式不正确
git remote add origin https://gitee.com/panyongjie/HFMessage.git
# 提交tag到远程git服务器
git push  - -tags 
# 提交代码到远程服务器
git push -u origin master  

在这里插入图片描述

4. Pod lib 版本管理

4.1. 添加Spec管理git仓库

我们在gitee上创建一个名为HFComponentSpec的git空项目,然后执行下面的命令将这个仓库添加到pod 远程仓库中

pod repo add HFComponentSpec https://gitee.com/panyongjie/HFComponentSpec.git

执行成功后,输入pod repo list 查看仓库是否添加成功

在这里插入图片描述

4.2 创建Spec版本

执行下列命令创建Spec版本并上传Spec git远程仓库上

pod repo push HFComponentSpec HFMessage.podspec --use-libraries --allow-warnings --verbose

上传成功后会出现下面的输出


在这里插入图片描述

四、使用私有Pod lib

创建一个名为PodLibTest的Application工程, 然后进入工程目录执行pod setup

1. PodFile配置

在PodFile文件中进行如下配置

# Uncomment the next line to define a global platform for your project
# platform :ios, '9.0'

# 因为pod 默认只会已github做为源进行搜索,如果使用了私有库则需要配置自己的私有库地址来作为源,这样pod搜索时就可以找到个人创建的私有库
source 'https://gitee.com/panyongjie/HFMessage.git'
source 'https://github.com/CocoaPods/Specs.git'

target 'PodLibTest' do
  # Comment the next line if you don't want to use dynamic frameworks
  use_frameworks!

  # Pods for PodLibTest

  pod 'HFMessage', '0.1.0'

end

2. 进行pod install

进入项目目录,先执行pod repo update, 然后执行pod install, 执行成功后打开项目可以看到如下的工程目录

在这里插入图片描述

3. 调用私有库

在这里插入图片描述

运行项目,可以看到调用正常


在这里插入图片描述

五、升级pod lib

1. 修改源代码文件

对项目源代码进行修改

2. 修改spec文件

在这里插入图片描述

3. 提交git源代码

同步git服务器代码到最新


在这里插入图片描述

将源代码提交到远程服务器上


在这里插入图片描述
在这里插入图片描述

4. 更新pod lib 远程仓库

执行下列命令进行pod lib 上传

pod repo push HFComponentSpec HFMessage.podspec --use-libraries --allow-warnings --verbose

上传成功后会出现下面的输出


在这里插入图片描述

git 上也可以看到最新的spec信息


在这里插入图片描述

5. 使用升级后的pob lib

执行pod repo update HFMessage,更新最新pod 远程仓库到本地。修改PodFile中的版本为0.2.0,然后在执行 pod install就可以了。

六、常见错误

1. Remote branch xxx not found in upstream

进行 pod repo push 操作的时候提示远程分支版本不存在

在这里插入图片描述

解决办法:先将pob lib 项目源代码上传到git服务器上并打上0.1.0的tag,然后在执行pod repo push操作

2. deployment_target不匹配

在这里插入图片描述

执行报错了,提示我们当前的项目ios的部署版本是13.2, 没有对应的pod lib版本。


image

修改ios 部署版本为9.3,然后再次进行pod install

3. An unexpected version directory Classes

执行pod install,命令行中提示’An unexpected version directory Classes was encountered’

在这里插入图片描述

这时因为你下载到本地的Spec仓库里面包含其它不必要的文件


在这里插入图片描述

删除掉除’HFMessage’和版本文件夹外的所有文件夹和文件,然后重新pod install
[图片上传失败...(image-dd97e9-1608864499737)]

4. Could not find compatible versions for pod

在这里插入图片描述

这是因为你没有创建名为HFMessage版本为0.3.2的pod lib仓库,按照上面的方式升级HFMessage版本0.3.2的pod lib仓库


在这里插入图片描述

然后再次执行pod repo update HFMessage,更新最新pod 远程仓库到本地


在这里插入图片描述

再次pod install就可以下载到最新版本到本地了


在这里插入图片描述

5. git错误

5.1 git remote add 执行无效

这时因为从网页上粘贴的命令行中带有多余空格,但是在命令行下又看不出来。只需要将此行命令进行手打就可以了

5.2 git push 出现merge 错误

虽然我们本地每次都将代码push到了git服务器上,但是可能因为缓存或者其它原因本地git版本不是最新的,所有每次push之前先执行一次"git pull"拉取一次最新的代码版本,然后在执行commit和push操作。

6. resource_bundle上传导致的错误

该文件夹内
s.resource_bundles = {
'lelePodsKit' => ['lelePodsKit/Assets/*/.xcassets']
}
资源文件不能copy进来 得拖到项目中再拖进来 不然报错

7.我的GitHub test

项目地址
https://github.com/godEyesLELE/lelePodsKit
仓库索引地址
https://github.com/godEyesLELE/lelePodsSpec

你可能感兴趣的:(2020-12-25)