pgyer document center
ios 的内测应用在安装时,很多人都遇到过安装失败的情况,安装失败的原因比较多,下面我们将一些常见原因总结如下,方便开发者进行排查。
请回到 ios 系统桌面,然后依次打开 设置
- 通用
- 描述文件与设备管理
,然后,点击对应描述文件进入后,再点击按钮 信任
即可。具体解决办法请见: 运行企业版应用
如果您是该应用的开发者,请检查应用的签名是否正确,这个问题出现的原因一般是由于应用的签名不正确导致的。一般来说,对于 adhoc 签名方式重点检查当前设备 udid 是否已经注册;对于 in-house 签名(即企业签名) 方式来说,需要重点检查证书是否被撤销。如果您不是这个应用的开发者,请联系开发者解决。
这个问题出现的原因,一般是由于用户已经从苹果官方 app store 上安装了相同的应用。解决办法是:先在您的设备中删除之前已经安装的应用,然后再从蒲公英安装即可。
这个问题一般是由于用户的网络,或者手机缓存错误造成的,可以尝试如下两个方法来解决:
原因一:开发者在打包app时,导出 ios app 的安装包文件(.ipa
文件)时,选择了 app-store 方式。
在导出 ios 的 .ipa
文件时,有些开发者选择了 app-store 方式,这种方式导出的 .ipa
文件,只适合于上传到苹果 app store,并不能通过蒲公英来安装。如果是这种方式导出的 .ipa
文件,传到蒲公英上时,蒲公英会显示“app-store版”,这种版本是不能通过蒲公英安装的。
原因二:在导出 ios app 的安装包文件(.ipa
文件)时,选择了 ad-hoc 方式,但是没有添加设备 udid。
在导出 ios 的安装包文件时,如果选择了 ad-hoc 方式(一般用于苹果个人开发者账户),那么,如果要某台设备可以安装,则必须要将这台设备的 udid 添加到导出安装包时所用的证书文件中(. mobileprovision
文件),才可以在这台设备上安装。
使用 ad-hoc 方式导出的安装包文件上传到蒲公英后,蒲公英会显示为“内测版”,同时会在应用管理中,显示出该安装包的证书中包含的 udid 列表。开发者可以根据显示出的 udid 列表,来排查某台设备的 udid 有没有被添加到安装包的证书中。
原因三:在导出 ios app 的安装包文件(.ipa
文件)时,选择了 in-house 方式,但是证书已过期或被撤销。
在导出 ios 的安装包文件时,如果选择了 in-house 方式(一般用于苹果企业开发者账户),此时,如果出现无法安装的情况,开发者可以检查一下自己的企业开发者证书是否已过期或是否被撤销。因为苹果对于企业开发者证书管理较为严格,所以开发者如果使用不当,可能会导致企业证书被苹果官方撤销,被撤销后的企业证书导出的安装包,也是无法正确安装的。
原因四:开发者在生成app安装包时,没有在 xcode 中设置正确的 architecture。
ios 应用的 architecture(架构),决定了这款 ios 应用可以在哪些设备机型上安装。例如,如果某个应用在 xcode 中只添加了 arm64
这一种 architecture,那么最终打包后的安装包文件上传到蒲公英后,对于 ipad mini、iphone5 等以下设备,都是无法安装的(因为这些设备都不是 arm64
架构)。换句话说,如果需要在某个设备上可以安装,app 就必须支持那个设备的 architecture。
所以,正确的解决方法是,在生成 app 安装包时,尽可能让 app 支持更多的 architecture。
具体操作方法是:在 xcode - build settings - architecture
中,增加 armv7
、armv7s
、arm64
,以便所有设备都可以安装。然后,将 "build active architecture only"
设置为 no
。对于各个 ios 设备支持的 architecture 类型。。
原因五:app 支持的 ios 系统版本,和当前设备系统版本不符。
app 支持的 ios 系统版本过低或者过高,都可能导致 app 无法安装成功。例如,如果某个 app 设置了只支持 ios 11.0 以上的系统时,那么,如果在低于这个版本的系统上安装时,是无法安装成功的。
因此,解决的方法也很简单,我们应该尽量让 app 尽可能支持更宽泛的系统版本。
具体操作方式是:在 xcode
- general
- deployment info
- deployment target
中,给 app 设置一个尽量低的版本,例如 ios 6.0。
原因六:设备上已经安装了这个app,且已经安装的 app 和要安装的 app 是用不同证书打包的。
这种情况下,也会造成 app 安装失败。解决的方式很简单,用户只需将设备上原来已经安装的 app 删除,再重新安装新的 app 即可。
原因七:info.plist
文件中的lsrequiresiphoneos
没有设置,或者设置了 no
。
对于 ios 的 app 来说,如果info.plist
文件中的lsrequiresiphoneos
没有设置,或者设置了 no
,那么由 xcode 导出的安装包(.ipa
包),就不会包含 payload
文件夹,而是被一个叫做 applications
的文件夹代替。这样的安装包在安装时,会被 ios 判定为无效的安装包,所以无法被正确安装。
解决方式也很简单,只需要将info.plist
文件中的lsrequiresiphoneos
设置为 yes
,然后重新打包即可。具体操作为:在 xcode 中打开 info.plist
文件,然后检查 lsrequiresiphoneos
是否已设置,如果没有设置,就添加一个,然后将 lsrequiresiphoneos
的类型设置为 boolean
,值设置为 yes
。
设置好以后,可以看到 info.plist
文件中显示 application requires iphone environment
的值为 yes
。
另外,还可以使用蒲公英的 mac os 客户端 来打包上传 app,蒲公英的 mac os 客户端在打包安装包时,自动处理了这个问题。
原因八:网络出现中断或异常。
遇到这种情况,用户可检查自己手机的所连接的网络是否稳定、速度是否正常等。能否打开其他网站,或者更换一个 wi-fi,或者由 wi-fi 换成 3g/4g 等,然后重新安装。
用这样的方式尝试后,一般都可以解决问题。
如果根据以上的方式进行排查后,依然无法解决问题,那么可以使用蒲公英的 mac os 客户端来查看安装日志。
蒲公英的 mac os 客户端中,提供了实时查看 app 安装日志的功能,开发者可以方便的根据 app 的安装日志,来准确的判断具体安装失败的原因,具体方法请见:查看ios的安装日志