原文: https://blog.csdn.net/xlyrh/article/details/79078271
要求:
1、ipa的下载地址放到plist的文件中,链接指定plist(plist格式见下文)
2、plist的链接要求一定是https的,而且必须是公网ssl,自签名及免费的https不可用。
3、链接格式要求一定是符合苹果规范的,itms-services://?action=download-manifest&url=https://****/***.plist
目前可以使用https测试用的域名:https://raw.githubusercontent.com/ (2018-01-16 测试通过)
具体方法:将plist上传到github上,查看plist内容页面上右上角点击“Raw”
使用该地址链接格式为https://raw.githubusercontent.com/用户名/项目名/master/xxxx.plist
拼接链接:itms-services://?action=download-manifest&url=https://raw.githubusercontent.com/用户名/项目名/master/xxxx.plist
在iphone手机中打开Safari,访问该链接,提示“在"iTunes"中打开链接吗?",点击打开
提示“raw.githubusercontent.com”要安装“XXXXX”,点击安装即可在线下载安装ipa。
.plist格式
<?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>http://xxxxxxxxxxxxxxxxxxx/xxx.ipa</string>
</dict>
<dict>
<key>kind</key>
<string>full-size-image</string>
<key>needs-shine</key>
<true/>
<key>url</key>
<string>http://xxxxxxxxxxxxxxxxxx.png</string>
</dict>
<dict>
<key>kind</key>
<string>display-image</string>
<key>needs-shine</key>
<true/>
<key>url</key>
<string>http://xxxxxxxxxxxxxxxxxx.png</string>
</dict>
</array>
<key>metadata</key>
<dict>
<key>bundle-identifier</key>
<string>com.xxxx.demo</string>
<key>bundle-version</key>
<string>1.0.0</string>
<key>kind</key>
<string>software</string>
<key>title</key>
<string>XXXX App download</string>
</dict>
</dict>
</array>
</dict>
</plist>
原文:https://blog.csdn.net/zhanghuiqi205/article/details/82942310
ios安装测试包时,除了直接用xcode安装外我们最常用的还有想fir.im等第三方分发平台,那么像fir.im这些平台是怎么做到扫码直接安装的呢,这就是使用了itms-services协议.
其实分发平台获取你上传的app后,会生成一个plist文件,通过它我们可以下载对应的ipa文件.
那么plist文件内容是这样的。内容主要是告诉我们下载ipa文件的地址和icon图片的下载地址。这个文件必须通过https的访问才可以。因为现在苹果规定必须以https的方式进行访问
同学们一定很好奇,这中间是怎么一个过程呢。其实是利用苹果自家的浏览器safari和itms-services协议来实现的。
通过itms-services协议,可以通过safari浏览器直接在iOS设备上安装应用程序。利用这种方式,只要在内网布置一个服务器,测试人员只需要通过测试设备的safari浏览器访问特定的url既可以实现安装
当我们上传我们的app到服务器上的时候,我们会把所有的地址存储起来,并把相关的信息都存储在数据库。这样就会在展示页显示我们app的信息:如图所示,此处我是关联了两个程序。其实就是一个字段相互引入各自的下载路径,通过判断设备来进行下载,来实现二维码合二为一。
接下来,在我们的二维码扫描页面,
然后我们看一下手机上,下载按钮连接的地址是什么。其实就是install.php中的内容,里面就是我们通过苹果的协议,来进行下载的连接。
我们来看看install的内容:
那么如果没有https的环境,也没关系,我们可以利用第三方的外链来实现。放到第三方平台,比如七牛云或者码云上去,我这里是放到了码云上去,只需要把这里的地址换成码云上源文件的地址就可以。
那么接下来我们就可以实现扫描二维码下载app到苹果和安卓手机了,那么我们看一下测试的效果:
那么到现在我们实现了通过另外一种方式安装苹果app的方法,这也是很多内部分发平台的实现原理。对于这种的安装方式,在打开APP的时候会提示是否信任此设备。这也是没有从苹果商店下载的好处,你需要去信任这个,至于位置就是在设置——》通用——》设备管理——》此处位置:
当然现在很多分发平台是有直接跳转到这里的功能的。
其实就是一个a标签的连接,直接跳转到设备管理的位置。
说了这么多,整个app的安装过程我们就讲述完了。然后就是可以愉快的使用我们的app了。那么总结一下,主要的知识点就是:
1.苹果app必须签名成功。
2.上传到服务器,获得信息和下载地址,得到两个文件,一个是plist文件和ipa文件,当然还有图片。
3.通过访问plist文件来达到下载ipa文件和图片的目的,使用了苹果的itms-services:///?action=download-manifest&url=一个https地址
4.信任设备。
5.其他知识点:二维合一,就是一个判断,和得到相互的下载地址,然后继续上述的协议,下载app。
<?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>http://xxxxxxxxxxxxxxxxxxx/xxx.ipa</string>
</dict>
<dict>
<key>kind</key>
<string>full-size-image</string>
<key>needs-shine</key>
<true/>
<key>url</key>
<string>http://xxxxxxxxxxxxxxxxxx.png</string>
</dict>
<dict>
<key>kind</key>
<string>display-image</string>
<key>needs-shine</key>
<true/>
<key>url</key>
<string>http://xxxxxxxxxxxxxxxxxx.png</string>
</dict>
</array>
<key>metadata</key>
<dict>
<key>bundle-identifier</key>
<string>com.xxxx.demo</string>
<key>bundle-version</key>
<string>1.0.0</string>
<key>kind</key>
<string>software</string>
<key>title</key>
<string>XXXX App download</string>
</dict>
</dict>
</array>
</dict>
</plist>
---------------------
作者:杨小扬
来源:CSDN
原文:https://blog.csdn.net/xlyrh/article/details/79078271
版权声明:本文为博主原创文章,转载请附上博文链接!