SDK Framework创建 CocoaPods 提交

前言:
公司常需要提供源码给客户,但是又有部分源码是不想给的,所以,打包成静态库是一个不错的选择,至于是.a还是.framework,看个人选择,如果头文件比较多的,我还是喜欢.framework,简洁,头文件收藏得深,本文章只是记录一下开发流程以供以后翻看,不足之处,请见谅,斧正。


说明:创建Framework的方法一般有两种,一个是xcode创建,一个是cocoaPods创建,因为创建后,需要将它发布到Pods上给人使用的,公司有部分代码需要隐私,所以我选择了用xcode创建了Framework后build出需要版本,再发布Pods上,但是如果代码不需要保密,可以直接用cocoaPods创建,这样子会省很多事情,利用需要用到cocoaPods管理的第三方框架等


1、创建Framework,添加一个简单的打印类

创建Framework

创建Framework

添加打印类
添加打印类

2、编辑、打包SDK,千万切记要General的Deployment Target选择支持的系统版本,尽量选择到最旧的8.0,这个没有选择的话,后面会影响很大

编译出真机和虚拟机使用的.framework,这里可以选择debug或者Release

编译framework

合并出一个兼容虚拟机和真机使用的.framework,特别说明一下,framework和a库有点区别,合并的文件是.framework里边的红色框住的这个文件,这个很重要

framework

合并命令:lipo -create 真机编辑文件路径 虚拟机编译文件路径 -output 合并后存放文件的路径

合并后的framework


至此,已经Framework就算完成了,正如上面所说,我们需要的是提供包给别人用的,所以接下来是如何将SDK放到Pods上面去


3、将Framework提交到github上

说明:因为Pods默认是基于git的代码管理,所以要将SDK丢到Pods上去,首先需要先放到git上。以下操作都是默认你已经有了github的账号了的

  • 首先,在git上创建一个空的新项目,特别注意,下面的初始化尽量、最好勾选上,还有那个License,也选择上,后面提交会用到


    创建项目
  • 然后将该项目克隆到本地,我为了方便查找,直接放到了桌面

git clone https://github.com/p****/C*******FrameworkTest.git
本地项目
  • 将上面弄好的SDK放到该项目中,并提交


    导入SDK
cd 到.git仓库的同级目录
git add .
git commit -m "注释说明comment log"
git push
git tag 1.0.1
git push --tags
  • 成功后会在终端见到一下内容,github的工作就差不多了,现在到Pods了
Total 0 (delta 0), reused 0 (delta 0)
To https://github.com/phyky/CocoaPodsFrameworkTest.git
 * [new tag]         1.0.1 -> 1.0.1

  • 注册trunk(邮箱和用户名),通过会收到【Please verify the session by clicking the link in the verification email that has been sent to 26******90@qq.com
pod trunk register 26******90@qq.com phyky --verbose
  • 去邮箱验证,将图中的红框连接拷到浏览器打开,完成验证


    验证
  • 查看注册信息
pod trunk me
- Name:     phyky
- Email:    26******90@qq.com
- Since:    September 10th, 02:02
- Pods:     None
- Sessions:
- September 10th, 02:02 - January 16th, 2019 02:05. IP:
  183.62.48.226
- September 10th, 02:29 - January 16th, 2019 02:29. IP:
  183.62.48.226
  • 创建.spec文件,该文件主要是配置一些项目到Pods的参数,极为重要。
pod trunk push ./PHYFrameworkTest.podspec
.spec文件
  • 配置.spec文件,部分重要的参数我标了一下注释,但是里边的很多参数我没有使用,因为这个SDK是很简单的,而且没有涉及到png和xib,具体参数使用,可另行查阅
#
#  Be sure to run `pod spec lint PHYFrameworkTest.podspec' to ensure this is a
#  valid spec and to remove all comments including this before submitting the spec.
#
#  To learn more about Podspec attributes see http://docs.cocoapods.org/specification.html
#  To see working Podspecs in the CocoaPods repo see https://github.com/CocoaPods/Specs/
#

Pod::Spec.new do |s|

  # ―――  Spec Metadata  ―――――――――――――――――――――――――――――――――――――――――――――――――――――――――― #
  #
  #  These will help people to find your library, and whilst it
  #  can feel like a chore to fill in it's definitely to your advantage. The
  #  summary should be tweet-length, and the description more in depth.
  #

  s.name         = "PHYFrameworkTest"
  s.version      = "1.0.1" //切记要和Git提交的版本号一致
  s.summary      = "Test for PHYFrameworkTest."

  # 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
  只是测试一下,信不信由你(just for test,no content)
                   DESC//这里的描述必须比上面的summary长,否则报警告

  s.homepage     = "https://github.com/phyky/CocoaPodsFrameworkTest.git"//填写地址
  # s.screenshots  = "www.example.com/screenshots_1.gif", "www.example.com/screenshots_2.gif"


  # ―――  Spec License  ――――――――――――――――――――――――――――――――――――――――――――――――――――――――――― #
  #
  #  Licensing your code is important. See http://choosealicense.com for more info.
  #  CocoaPods will detect a license file if there is a named LICENSE*
  #  Popular ones are 'MIT', 'BSD' and 'Apache License, Version 2.0'.
  #

  #s.license      = "MIT (example)"
  //特别重要,这就是上面提到的新建Git项目的时候,初始化需要选择的LICENSE,没有这个提交会报错
  s.license      = { :type => "MIT", :file => "LICENSE" }


  # ――― Author Metadata  ――――――――――――――――――――――――――――――――――――――――――――――――――――――――― #
  #
  #  Specify the authors of the library, with email addresses. Email addresses
  #  of the authors are extracted from the SCM log. E.g. $ git log. CocoaPods also
  #  accepts just a name if you'd rather not provide an email address.
  #
  #  Specify a social_media_url where others can refer to, for example a twitter
  #  profile URL.
  #

  s.author             = { "" => "" }
  # Or just: s.author    = ""
  # s.authors            = { "" => "" }
  # s.social_media_url   = "http://twitter.com/"

  # ――― Platform Specifics ――――――――――――――――――――――――――――――――――――――――――――――――――――――― #
  #
  #  If this Pod runs only on iOS or OS X, then specify the platform and
  #  the deployment target. You can optionally include the target after the platform.
  #

  # s.platform     = :ios
  //平台、系统版本必填,否则会报osx相关的警告,也是提交不了,前面打包Framework的时候提到的重要性
   s.platform     = :ios, "8.0"

  #  When using multiple platforms
  # s.ios.deployment_target = "8.0"
  # s.osx.deployment_target = "10.7"
  # s.watchos.deployment_target = "2.0"
  # s.tvos.deployment_target = "9.0"


  # ――― Source Location ―――――――――――――――――――――――――――――――――――――――――――――――――――――――――― #
  #
  #  Specify the location from where the source should be retrieved.
  #  Supports git, hg, bzr, svn and HTTP.
  #

  s.source       = { :git => "https://github.com/phyky/CocoaPodsFrameworkTest.git", :tag => "#{s.version}" }


  # ――― Source Code ―――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――― #
  #
  #  CocoaPods is smart about how it includes source code. For source files
  #  giving a folder will include any swift, h, m, mm, c & cpp files.
  #  For header files it will include any header in the folder.
  #  Not including the public_header_files will make all headers public.
  #
//特别重要,这里边的.h或者.m文件不能只是配到.framework,否则找不到,报错
  s.source_files  = "lib/PHYFrameworkTest.framework/Headers/*.{h}"
  #s.exclude_files = "Classes/Exclude"

  # s.public_header_files = "Classes/**/*.h"
//特别重要,这里必须配置,否则上传成功,找不到.framework,只有头文件
  s.vendored_frameworks = 'lib/PHYFrameworkTest.framework'

  # ――― Resources ―――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――― #
  #
  #  A list of resources included with the Pod. These are copied into the
  #  target bundle with a build phase script. Anything else will be cleaned.
  #  You can preserve files from being cleaned, please don't preserve
  #  non-essential files like tests, examples and documentation.
  #
//如果有用到资源的,路径配置参考上面的s.source_files
  # s.resource  = "icon.png"
  # s.resources = "Resources/*.png"

  # s.preserve_paths = "FilesToSave", "MoreFilesToSave"


  # ――― Project Linking ―――――――――――――――――――――――――――――――――――――――――――――――――――――――――― #
  #
  #  Link your library with frameworks, or libraries. Libraries do not include
  #  the lib prefix of their name.
  #

  # s.framework  = "SomeFramework"
  # s.frameworks = "UIKit", "Foundation"

  # s.library   = "iconv"
  # s.libraries = "iconv", "xml2"


  # ――― Project Settings ――――――――――――――――――――――――――――――――――――――――――――――――――――――――― #
  #
  #  If your library depends on compiler flags you can set them in the xcconfig hash
  #  where they will only apply to your library. If you depend on other Podspecs
  #  you can include multiple dependencies to ensure it works.

  # s.requires_arc = true

  # s.xcconfig = { "HEADER_SEARCH_PATHS" => "$(SDKROOT)/usr/include/libxml2" }
  # s.dependency "JSONKit", "~> 1.4"

end

  • 校验spec文件是否正确,这步可能会抛出很多警告或者错误,对照着去修改就行
pod spec lint
  • 检验通过,提示以下
 -> PHYFrameworkTest (1.0.1)
Analyzed 1 podspec.
PHYFrameworkTest.podspec passed validation.
  • 提交到Pods,成功会有以下的提示
pod trunk push ./PHYFrameworkTest.podspec
Congrats
PHYFrameworkTest (1.0.1) successfully published
September 10th, 03:23
https://cocoapods.org/pods/PHYFrameworkTest
Tell your friends!

进行到这里,SDK就算是完整创建并提交完了,迫不及待去【pod search PHYFrameworkTest】一下,发现并没有找到,更新一下pod,删除掉pod本地的搜索缓存【~/Library/Caches/CocoaPods】,就会搜索到了。以下是最后的成果


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

推荐阅读更多精彩内容