整个流程,包括Github创建项目、上传项目,到最后的支持Cocoapods。
步骤如下:
- GitHub创建存储库,上传代码,并且克隆项目到本地
- 注册CocoaPods账号
- 创建podspec文件,配置podspec文件信息,并且验证
- 在Github上创建项目release版本
- 上传代码到CocoaPods
- 错误信息s.source_files解决办法
一、GitHub创建存储库,上传代码,并且克隆项目到本地
- 打开github.com,然后创建自己的项目工程:
- 通过终端命令或者github客户端将项目 clone 到本地
并且把需要支持pod的文件或者demo放到里面,文件夹如下图所示:
JYWKWebViewDemo是示例demo,JYWKWebView就是提供给他人使用的库,然后提交同步到Github。
二、 注册CocoaPods账号
- 终端输入
// pod trunk register 邮箱地址 '用户名' --description='描述信息'
pod trunk register 505340739@qq.com 'zjy' --description '创建CocoaPods'
-
然后打开邮件中的链接, 这样就成功注册了Cocoapods账号。
检查是否创建成功,如下图表示创建成功
pod trunk me
三、 创建podspec文件,配置podspec文件信息,并且验证
- 打开终端,cd到项目文件夹下
- 创建.podspec
// JYWebView为你需要支持pod的库名,文件名
pod spec create JYWebView
- 编辑.podspec文件
项目文件夹下可用Xcode方式打开,建议里面内容全部删除,将需要配置的信息进行 copy,然后修改。
Pod::Spec.new do |s|
s.name = "JYWKWebView"
s.version = "1.0.0"
s.summary = "WKWebView简单封装"
s.ios.deployment_target = '9.0'
s.homepage = "https://github.com/CoderJYZhu/JYWKWebView"
s.license = { :type => "MIT", :file => "LICENSE" }
s.author = { "某天" => "505340739@qq.com" }
s.source = { :git => "https://github.com/CoderJYZhu/JYWKWebView.git", :tag => s.version }
s.source_files = "JYWKWebView/*.{h,m}"
s.requires_arc = true
end
下面列出常用配置信息:
s.name:名称,pod search 搜索的关键词,注意这里一定要和.podspec的名称一样,否则报错
s.version:版本号
s.ios.deployment_target:支持的pod最低版本
s.summary: 简介
s.homepage:项目主页地址
s.license:许可证
s.author:作者
s.social_media_url:社交网址,这里我写的微博默认是Twitter,如果你写Twitter的话,你的podspec发布成功后会@你
s.source:项目的地址
s.source_files:需要包含的源文件
s.resources: 资源文件
s.requires_arc: 是否支持ARC
s.dependency:依赖库,不能依赖未发布的库
s.dependency:依赖库,如有多个可以这样写
更多配置信息可以自行百度。
附上官网链接:specs-and-specs-repo
关于资源文件更详细的写法,可以看这篇文章:给 Pod 添加资源文件
source_files:写法及含义建议大家写第一种或者第二种
"JYWebView/*
""JYWebView/JYWebView/*.{h,m}"
"JYWebView/**/*.h"
“*” 表示匹配所有文件
“*.{h,m}” 表示匹配所有以.h和.m结尾的文件
“**” 表示匹配所有子目录
- 验证.podspec文件是否合法
pod lib lint
下图表示验证通过:
四、在Github上创建项目release版本
一般也叫做打Tag步骤,可以用命令行操作
点击Publish release即可。创建完成后如图所示:
五、上传代码到CocoaPods
- 终端cd到项目文件夹下,首先检查文件有效性
pod spec lint
通过验证:
- 上传到CocoaPods
// pod trunk push xxx.podspec —allow-warnings (验证有警告可以使用 —allow-warnings忽略)
pod trunk push JYWKWebView.podspec --allow-warnings
- 验证是否上传成功
// 使用pod search XXX搜索
pod search JYWKWebView
-
如果搜索不到出现下图问题:
执行pod setup其实在你安装CocoaPods执行pod install时,系统会默认操作pod setup,然而由于中国强大的墙可能会pod setup不成功。这时就需要手动执行pod setup指令,如下:
终端输入:pod setup
会出现Setting up CocoaPods master repo,稍等几十秒,最底下会输出Setup completed。说明执行pod setup成功。
如果pod search操作还是搜索失败,如下:
终端输入:pod search JYWKWebView删除~/Library/Caches/CocoaPods目录下的search_index.json文件
pod setup成功后,依然不能pod search,是因为之前你执行pod search生成了search_index.json,此时需要删掉。
终端输入:rm ~/Library/Caches/CocoaPods/search_index.json
删除成功后,再执行pod search。
执行pod search
终端输入:pod search JYWKWebView(不区分大小写)
输出:Creating search index for spec repo ‘master’.. Done!,稍等片刻······就会出现所有带有afnetworking字段的类库。
六、错误信息s.source_files解决办法
验证.podspec文件是否合法过程中遇到过一个问题就是:
s.source_files = 'Classes/*.{h,m}'
s.source_files = 'Classes/DropDownMenu.{h,m}'
s.source_files = 'Classes'
s.source_files = 'Classes/**/*.{h,m}'
然后就是无休止的修改s.source_files,上面这几种路径格式我都试过了,也确认路径层次没有问题但是验证就是通不过,还是上图的错误。不知道是不是bug。然后在网上看到别人的路径设置,也跟着试了下,针对我的项目结构,先把s.source_files路径设置为:
s.source_files = "JYWKWebView/JYWKWebView.h"
然后就莫名的验证成功了,并且后续也上传CocoaPods成功了!但是这样上传的项目在后续pod下载的时候只有JYWKWebView.h这一个文件。所以还得重新修改上传。
之后再回头将s.source_files修改回来,将release版本升级为1.0.1、然后在上传CocoaPods:
s.source_files = "JYWKWebView/*.{h,m}"
并且也上传成功了,到这就大功告成了。至于原因没搞清楚,反正就是成功了。
参考文章:
https://www.cnblogs.com/lurenq/p/6785781.html
https://www.cnblogs.com/weiming4219/p/7699699.html
https://blog.csdn.net/conglin1991/article/details/55096422