美文网首页
APP企业签名版本与App Store版本共存问题

APP企业签名版本与App Store版本共存问题

作者: 墨柒_js | 来源:发表于2019-01-19 20:00 被阅读0次
    环境

    由于公司的项目属于不好上架到App Store的项目,所以之前一直用企业签名的形式分发应用,但由于种种原因,现需要上线到App Store。

    问题

    用户已经习惯了在官网下载APP,并且用户量特别大,万级别的,每一个动作都必须小心谨慎,要上线到App Store的话就有两个来源了。此时最难处理的一个点是版本更新!有时候强制更新有时候不强制,初始化的时候调用版本更新相关接口。

    方案

    1.直接源码上线,不做代码修改。当有新版本的时候用户点击更新一致跳转到官网下载页,在下载页分离出一个App Store入口,用户也可以选择跟以前一样直接下载企业签名版本。
    问题:
    a.两个版本不会兼容,如果此前下载的是企业版本,想要更新App Store版本*应该*是必须先卸载的,反之一样;
    b.企业版上线了,可能App Store还没审核通过,带来诸多需要解决的问题比如什么时候提示用户版本更新。

    2.修改bundle ID分离APP,就变成了两个APP,用户通过不同渠道可以同时安装两个APP,App Store版本的不再调用后台版本更新接口,直接从App Store获取新版本。
    问题:
    a.有些使用bundle ID注册的第三方(目前就分享)将不可正常使用,唯一的解决办法就是从那些三方网站申请一个全新的id对应。如此账号就会越来越多,分离工作也越来越复杂,不太推荐。
    b.其实还是需要调用后台特定更新接口,因为不知道是否需要强制更新。

    3.修改APP名称,通过APP名称(也可以是别的标识,具体可用哪些方案后面给思路)判断是否企业版。此时bundle ID一样还是同一个APP,分别对企业签名版和App Store版本做不同的更新处理。
    问题: 这就是我选择的方案,问题大同小异,只是对用户来说体验更好。
    下面说具体做法

    //获取当前版本号
       let infoDictionary = Bundle.main.infoDictionary
       let appShortVersion = infoDictionary!["CFBundleShortVersionString"] as! String
    /*
    这里注意下CFBundleShortVersionString与CFBundleVersion的区别,之前我们用CFBundleVersion作为版本升级的依据,
    现在发现通过App Store获取的版本信息没有这个数据,所以改为用前者。
    */
    

    获取App Store版本的接口为http://itunes.apple.com/lookup?id=********,下面是返回扥数据结构和部分数据

    //App Store版本更新model
    struct AppStoreVersionModel: HandyJSON {
        var results: [ResultsVersionModel] = [ResultsVersionModel]()
        var resultCount: NSInteger = 0
    }
    
    struct ResultsVersionModel: HandyJSON {
        var releaseNotes: String = ""//版本更新内容
        var version: String = "" //版本号
        var bundleId: String = ""
        var releaseDate: String = "" //发布时间 年月日时分秒
        var trackName: String = "" //应用程序名称
        var screenshotUrls: [String] = [String]() //展示介绍图
        var sellerName: String = ""//开发者或公司
        
    }
    

    我会先请求后台的版本接口,不过只拿到其中的是否强制更新的数据,先判断是否需要更新-->需要更新-->判断是否App Store版本-->是-->请求上面接口,顺便把是否强制更新传过去,其余的版本介绍等都直接拿App Store的数据-->点击更新的时候直接open https://itunes.apple.com/app/id*******就自动跳到App Store下载页了。反之就是跳官网爱怎么处理就怎么处理。
    这样做的结果就是当有版本更新的时候,企业签名版本的会直接安装更新,App Store版本的还需要获取App Store的版本信息,有新版本才会弹出更新提示。

    ***另外,我上线的是大陆外的App Store区域,所以http://itunes.apple.com/lookup?id=******** 或者 https://itunes.apple.com/app/id*******/com后面要不要加上/cn需要看自己的需求。

    ***判断是否是企业版的思路:我们可以通过本地的包获得APP的名字,自然可以获得其它更多信息,在打包的时候也可以做很多处理,比如plist新增一些标识字段等,其实是变相的改了代码。

    相关文章

      网友评论

          本文标题:APP企业签名版本与App Store版本共存问题

          本文链接:https://www.haomeiwen.com/subject/rivzdqtx.html