本文介绍: 在iOS项目中,经常使用`cocoadpods`来进行依赖管理以及三方引入等。引入三方库一般会有几种形式:一、在`Pods`目录可以直接看到源代码开源库,如`AFNetworking`,`Masonry`等常见开源库。二、在`Pods`目录下拉取的项目文件只能看到对应的`头文件`和`资源文件`的闭源库,如`AlipaySDK`和`WechatOpenSDK`等,这种三方库一般涉及到商业逻辑安全性方面的考量,不能开源

iOS项目中,经常使用cocoadpods来进行依赖管理以及三方引入等。引入三方库一般会有几种形式:一、在Pods目录可以直接看到源代码的开源库,如AFNetworkingMasonry等常见开源库。二、在Pods目录下拉取的项目文件只能看到对应头文件资源文件闭源库,如AlipaySDKWechatOpenSDK等,这种三方库一般涉及到商业逻辑安全性方面的考量,不能开源。其中,AlipaySDK是以.framework的形式提供给用户WechatOpenSDK则提供.a文件形式。本文说明iOS中动静态库的一些基本概念,以及系统描述如何创建一个自定义.a或者.framework库,并通过cocoapods的形式供三方厂商使用

静态库和动态库的区别使用场景

iOS项目中经常使用到三方库有.a文件.framework文件或者.dylib文件

.framework

FrameworkiOS/MacOS平台下的一种打包方式,将编译生成二进制文件头文件资源文件统一打包最后生成文件可以静态可以动态iOS8以后允许创建自定义framework但是,使用到系统framework是动态库,而自己创建的自定义framework则是静态库。

.dylib

.dylib为动态库。

.a

.a是纯二进制文件,可以将不希望别人看到的源文件封装起来。提供给三方使用时,需要.h文件配合使用

动态库与静态区别

动态库在编译中不会被拷贝目标程序中,只有程序真正运行起来,才会被加载使用。像系统的的UIKit.framework等动态库,iPhone中的每个app都会用到,但并不会都拷贝一份到各自的app,而是共用系统中的一份。这样就会减少App的大小,同时,如果系统升级,也方便对整个库进行替换,不需要每个app打包一遍。

静态库则刚好和动态库相反,编译的时候会被直接拷贝一份,复制目标程序中,这样最终编译出来的ipa包体积会增大。但是,其优点是使用方便。

在iOS8之前,系统并没有开放自定义framework开发,创建的framework其实也是静态文件。iOS8之后,可以创建自定义framework动态库,但是跟系统提供的还是有区别,整个库文件依然会被复制到iOS的目标App中。所以,对于我们来说,自定义framework其实也是一个升级版的静态库。

我们实际开发自己的SDK时,使用framework.a文件都是比较常用的方式。两者的主要区别framework头文件资源文件、二进制文件都打包在一起,方便使用。而.a文件则只是一个静态文件,需要同时配合.h头文件来使用。如下则是AlipaySDK-iOSWechatOpenSDK分别使用.framework.a的两种形式。

AlipaySDK-iOS WechatOpenSDK
截屏2023-03-13 13.53.34 截屏2023-03-13 13.51.54

CocoaPods库创建及使用

我们要开发SDK三方厂家使用,则面临许多问题需要解决。如:SDK中可能会依赖其他的三方库,而客户项目中也可能会包含同样的三方库;集成过程可能会比较复杂版本控制问题。并且,在开发过程SDK也是要不断地运行测试的,如果使用最原始的方法,不断地导出导入到Demo项目中,整个开发过程会变得非常复杂和繁琐。

所以我们开发方式选取目前iOS中最常用的三方库和框架管理工具CocoaPods。创建一个我们自己CocoaPods库进行开发发布SDK项目

CocoaPodsgit库关系和结构

平时我们会在两个地方找到cocopods三方库的集成说明一个github等开源网站上,会看到源码中包含有.podspec文件,并一般会在README.md文件中有集成说明。另一个则是在一些三方厂商说明文档中,如微信开放平台JPush官方文档。

github中,我们看到的是源码pod配置文件所在位置。我们真正使用pod install下载安装三方库的时候,其源码文件则是从CocoaPods官方库中下载的。

CocoaPods 官方库、私有库、本地

CocoaPods官方库是CocoaPods维护的一个官方仓库,我们所使用的大部分三方库都是从官方库中下载下来的。

我们也可以不将开发好的库提交CocoaPods官方库,而是存放自己私有仓库中。这样,可以自由控制访问权限,一般公司项目进行组件化开发时候比较常用。在Podfile中,只需要添加私有库的source即可如下

source 'https://github.com/yourPrivateRepo/yourPrivateSpecs.git'

target 'YourApp' do
  pod 'YourPrivateLibrary', '~> 1.0'
end

本地库则是pod库在本地磁盘存放,在项目中使用时,直接在Podfile添加本地路径如下

target 'YourApp' do
  pod 'YourLocalLibrary', :path => '/path/to/your/local/library'
end

CocoaPods库创建

使用命令创建SDK项目库

pod lib create DemoSDK

接下来会有几个问题需要挨个输入,根据各自的配置进行输入。

截屏2023-03-13 16.57.36

接着会自动创建项目以及demo项目,并自动运行Pod install打开项目文件。生成的项目结构如下所示

截屏2023-03-13 16.59.54

这里,由于我电脑配置,创建好的.podspec文件中s.homepage.author以及s.source默认使用了我的github账号相关信息

.podspec文件对于pod库的创建至关重要,根据不同的需求修改配置相关参数实现最终需求

CocoaPods库中隐藏源码,只上传编译完成后的framework

创建完SDK项目文件后,因为我们的项目是要给三方厂商使用,不管是使用私有库还是共有库提供给对方,都不能将自己的源码暴露出来。所以我们目前最大需求就是不能将SDK源码暴露,只能提供最终编译好的.a或者.framework文件。

实现类似AlipaySDKWechatOpenSDk只提供二进制文件,不暴露源码,需要满足两个条件

  1. 将源码上传到git私有库中

这个很好理解,如果项目git仓库本身是公开的,则源码也就是无法隐藏了。

  1. 修改.podspec文件参数去掉s.source_files参数,并添加s.vendored_frameworks字段

s.source_files参数指定了源文件在本地路径,在.podspec文件中去掉s.source_files字段后,则使用pod trunc push命令不会将源文件上传到CocoaPods官方库中。

如果使用git私有库给第三方使用,则第三方厂商必须有用这个仓库的访问权限才可以使用。如果这种情况下也需要第三方厂商隐藏源文件,则最好创建一个新的私有库,只存放最终生成.a文件和.framework以及.podspec文件,然后将这个仓库需要厂商开放访问或者直接将这个仓库开源。

原文地址:https://blog.csdn.net/tarig/article/details/129532551

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_20180.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注