背景
iOS端APP上传ipa,供测试下载的几种方式:
- 苹果自己的TestFlight
- 直接给测试ipa包
- 上传至三方管理平台(蒲公英、fir.im等)
- 。。。
鉴于ipa包上传至三方平台,存在安全泄露、资质审核,项目被下等问题。我们其实可以仿照这些三方平台,在自己公司服务器上搭建一个上传下载ipa平台。接下来着重记录下,这种平台的大致逻辑。不全面之处,欢迎大家批评指正。
核心逻辑
其他三方平台其实都是利用safari和itms-services协议来实现的。
itms-services://?action=download-manifest&url=https://tinln.oss-cn-shanghai.aliyuncs.com/appname.plist
Plist文件的内容如下
plist必须是https的协议
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>items</key>
<array>
<dict>
<key>assets</key>
<array>
<dict>
<key>kind</key>
<string>software-package</string>
<key>url</key>
<string>(ipa包路径)</string>
</dict>
<dict>
<key>kind</key>
<string>display-image</string>
<key>needs-shine</key>
<true/>
<key>url</key>
<string>(icon路径)</string>
</dict>
<dict>
<key>kind</key>
<string>full-size-image</string>
<key>needs-shine</key>
<true/>
<key>url</key>
<string> (icon包路径)</string>
</dict>
</array>
<key>metadata</key>
<dict>
<key>bundle-identifier</key>
<string>《APP的Bundle ID》</string>
<key>bundle-version</key>
<string>《APP的版本号》</string>
<key>kind</key>
<string>software</string>
<key>title</key>
<string>《APP的名称》</string>
</dict>
</dict>
</array>
</dict>
</plist>
上传下载的大致流程
上传
点击上传,选择要上传的ipa,前端同事有插件,获取到ipa包里的appLogo、名字、版本、build号
点击开始上传,后端根据前端上传的信息把ipa放在服务器的目录下,按照appName/version/build的路径存放ipa包,生成一个ipa对应的ipaUrl,
后端同事根据前端上传的信息,动态修改上边plist文件的对应的内容,主要是software-package:上边生成的ipaUrl,也存放在对应目录下,生成一个plistUrl.
下载。手机端安装
用户点击安装,其实就是调用了itms-services://?action=download-manifest&url=上边生成的plistUrl,通过itms-services协议,在safari浏览器直接在iOS设备上安装应用程序。
总结
- ipa包是签名成功的
- iPhone的udid在开发证书下
- plist必须是https的协议
- 后端生成ipa包的url,动态修改plist,再生成plist对应url
- 前端下载按钮调用itms-services协议方法
蒲公英、fir.im之类的分发平台大概也就是这么做的,当然了他们做的功能更全面,我们这只是基础够用。公司的某个app被三方的分发平台强制下架了,所以我们就自己做了一个,在这里把大概流程记录一遍,希望可以帮助有需要的老哥吧。欢迎批评指正~