這里使用的代碼托管平臺(tái)是碼云上創(chuàng)建。
還可以使用github(之前不能免費(fèi)創(chuàng)建私有庫(kù),但現(xiàn)在可以了)、Coding等。
操作步驟:
一、創(chuàng)建兩個(gè)私有倉(cāng)庫(kù)
二、創(chuàng)建 spec repo
三、創(chuàng)建pod所需項(xiàng)目工程文件,并上傳到pod遠(yuǎn)程私有庫(kù)
四、向私有的spec Repo遠(yuǎn)程倉(cāng)庫(kù)中提交podspec
五、使用創(chuàng)建的私有pod庫(kù)
六、私有庫(kù)更新
一、創(chuàng)建兩個(gè)私有倉(cāng)庫(kù)
一個(gè)存放repo,一個(gè)存放pod所需項(xiàng)目工程文件
repo庫(kù)

pod庫(kù)

注意:
1、選擇私有
2、repo庫(kù)默認(rèn)選擇初始化
3、pod庫(kù)默認(rèn)不初始化
二、創(chuàng)建 spec repo
1、查看本地倉(cāng)庫(kù)
pod repo

2、添加遠(yuǎn)程repo庫(kù)
pod repo add 倉(cāng)庫(kù)名 倉(cāng)庫(kù)SSH(HTTPS)地址
pod repo add hftestrepo https://gitee.com/****/hftest-repo.git
添加之后,再次執(zhí)行pod repo 查看是否成功

還可以 通過(guò) ~/.cocoapods/repos 到對(duì)應(yīng)路徑下查看

三、創(chuàng)建pod所需項(xiàng)目工程文件,并上傳到pod遠(yuǎn)程私有庫(kù)
1、設(shè)定一個(gè)目標(biāo)文件并創(chuàng)建私有庫(kù)
cd 目標(biāo)文件夾
pod lib create HFTestKit (HFTestKit私有倉(cāng)庫(kù)名)


創(chuàng)建成功之后會(huì)自動(dòng)打開(kāi)上述工程文件。

1、pod lib create 創(chuàng)建成功的工程
2、選項(xiàng)中勾選得到示例工程
3、索引文件
4、自定義pod庫(kù)代碼位置
索引文件,相關(guān)字段有解釋?zhuān)梢圆榭?a target="_blank">cocoapods官方文檔了解更多。
Pod::Spec.new do |s| s.name = 'HFTestKit' s.version = '0.1.0' s.summary = 'A short description of HFTestKit.' # This description is used to generate tags and improve search results. # * Think: What does it do? Why did you write it? What is the focus? # * Try to keep it short, snappy and to the point. # * Write the description between the DESC delimiters below. # * Finally, don't worry about the indent, CocoaPods strips it! s.description = <<-DESC TODO: Add long description of the pod here. DESC s.homepage = 'https://gitee.com/****/hftest-kit' # s.screenshots = 'www.example.com/screenshots_1', 'www.example.com/screenshots_2' s.license = { :type => 'MIT', :file => 'LICENSE' } s.author = { '****' => '****' } s.source = { :git => 'https://gitee.com/****/hftest-kit.git', :tag => s.version.to_s } # s.social_media_url = 'https://twitter.com/<TWITTER_USERNAME>' s.ios.deployment_target = '10.0' s.source_files = 'HFTestKit/Classes/**/*' # s.resource_bundles = { # 'HFTestKit' => ['HFTestKit/Assets/*.png'] # } # s.public_header_files = 'Pod/Classes/**/*.h' # s.frameworks = 'UIKit', 'MapKit' # s.dependency 'AFNetworking', '~> 2.3' end
homepage:pod遠(yuǎn)程私有倉(cāng)庫(kù)地址,不帶.git
source:pod遠(yuǎn)程私有倉(cāng)庫(kù)地址,帶.git
注意修改為創(chuàng)建好的遠(yuǎn)程私有pod庫(kù)地址。
2、驗(yàn)證本地倉(cāng)庫(kù)
先cd 到HFTestKit路徑下,然后執(zhí)行
pod lib lint HFTestKit.podspec --allow-warnings
建議加—allow-warnings 因?yàn)橛芯鏁?huì)導(dǎo)致失敗。如果你能都解決警告也可以放開(kāi)。
得到 HFTestKit passed validation. 繼續(xù)執(zhí)行。
3、在Example工程中驗(yàn)證
增加一些類(lèi)

然后到Example工程下,執(zhí)行
pod install
打開(kāi)Example工程

4、將本地pod庫(kù)上傳到遠(yuǎn)程私有pod庫(kù)
cd 到 HFTestKit路徑下
git add .git
git commit -m "add manager"git remote add origin https://gitee.com/lisa_1900/hftest-kit.git
git push https://gitee.com/****/hftest-kit.git main
注意:

5、指定tag
git tag 0.1.0 #這里的版本號(hào)必須和podspec中的s.version值相同
git push --tags
四、向私有的spec Repo遠(yuǎn)程倉(cāng)庫(kù)中提交podspec
hftestrepo是本地私有索引庫(kù)。
cd 到HFTestKit文件夾
pod repo push hftestrepo HFTestKit.podspec --allow-warnings --use-libraries
//--allow-warnings:加上該選項(xiàng),驗(yàn)證時(shí)如果有警告會(huì)忽略警告,否則無(wú)法驗(yàn)證通過(guò)
//--use-libraries:如果依賴(lài)了靜態(tài)庫(kù)就需要加上該選項(xiàng)

遠(yuǎn)程索引庫(kù)

本地索引庫(kù)

創(chuàng)建成功。
五、使用創(chuàng)建的私有pod庫(kù)
新建一個(gè)工程
Podfile文件內(nèi)
use_frameworks!
platform :ios, '10.0'
# 遠(yuǎn)程私有庫(kù)
source 'https://gitee.com/lisa_1900/hftest-repo.git'
target 'HFRepoDemo' do
pod 'HFTestKit'
end
執(zhí)行pod install
#import "ViewController.h"
#import <hftestkit/HFTestUtil.h>
#import <hftestkit/HFTestManager.h>
@interface ViewController ()
@end
@implementation ViewController
- (void)viewDidLoad {
[super viewDidLoad];
// Do any additional setup after loading the view.
self.view.backgroundColor = [UIColor redColor];
[HFTestUtil hfUtil];
[HFTestManager hfManagerMethods];
}
@end
可以正常使用。
因?yàn)槲覀兊膫}(cāng)庫(kù)都是私有的,所以在哪里需要安裝的話(huà),需要有對(duì)這兩個(gè)私有倉(cāng)庫(kù)的訪(fǎng)問(wèn)權(quán)限就好,發(fā)布公有的類(lèi)似,只是發(fā)布到了官方的 podspec 倉(cāng)庫(kù)。
六、私有庫(kù)更新
1、修改xxx/xxx/Classes文件夾下對(duì)應(yīng)的庫(kù)文件
2、更新測(cè)試工程的Pod庫(kù)文件: pod update --no-repo-update
3、更新xxx.podspec文件的配置信息, 版本號(hào)一定要改
4、提交代碼到遠(yuǎn)程倉(cāng)庫(kù): git push
5、更新tag標(biāo)簽:git tag -a 0.2.0 -m "0.1.0"git push --tags
6、更新遠(yuǎn)程和本地的私有索引庫(kù): pod repo push MyRepo XXX.podspec --allow-warnings注意:
--no-repo-update:安裝pods之前不要更新pods倉(cāng)庫(kù)可以install、pod的速度更快一些。
1、修改xx/xx/Classes文件夾下的類(lèi):新增幾個(gè)類(lèi)

2、Example 工程 執(zhí)行
pod update --no-repo-update

3、修改podspec文件的配置信息, 版本號(hào)一定要改

4、代碼提交修改并推送到遠(yuǎn)程私有pod庫(kù)
git add .
git commit -m "commit message"
git push
5、更新tag,并推送至遠(yuǎn)程私有庫(kù)
git tag 0.2.1 #這里的版本號(hào)必須和podspec中的s.version值相同
git push --tags
6、更新遠(yuǎn)程和本地的私有索引庫(kù)
pod repo push hftestrepo HFTestKit.podspec --allow-warnings --use-libraries
pod repo push 本地私有索引庫(kù)名稱(chēng) XXX.podspec
注意:
多操作幾次,就可以熟練掌握的。