iOS9中如何适配http,Bitcode,设置sina,qq,weChat配置Scheme白名单

iOS9.0SDK在编译的时候,默认所有从NSURLConnection、CFURL和NSURLSession发出的http请求,都改为https请求。由于AFNetworking版本底层是用了NSURLConnection,所以使用AFNetworking的app都将受到影响。对于这个问题的解决办法有三种,一:让服务器更新,使用https,以解析相关的数据。

二:在info.plist做些配置,让其暂时倒回到不安全的网络传输协议(http协议)。下面详细来说下这两种方案。

方案一:让服务器更新。

第一种方案是最佳的,因为使用http的话,会存在以下主要风险:

1、窃听风险:第三方可以获得通信内容。

2、篡改风险:第三方可以修改通信内容。

3、冒充风险:第三方可以冒充他人来进行通信。

而使用https所带给我们的好处如下:

1、所有信息都是加密传播,第三方无法窃取。

2、具有校验机制,一旦通信内容被篡改,通信双方可以立即发现。

3、配备身份证书,防止他人冒充。

但是就目前情况来看,让服务器更新的代价太大,大的公司应该很大可能会让服务器更新,一般公司会采用第二种方案。

方案二:暂时倒回到不安全的网络传输协议(http协议)

(1)、在info.plist中增加一个NSAppTransportSecurity字段,类型是字典。

(2)、然后给其增加一个Key:NSAllowsArbitraryLoads,类型是Boolean类型,值为YES。

二:Bitcode

先看下Apple对其的解释,如图:

[cpp] view plaincopy

  1. Bitcode is an intermediate representation of a compiled program. Apps you upload to iTunes Connect
  2. that contain bitcode will be compiled and linked on the App Store. Including bitcode will allow Apple
  3. to re-optimize your app binary in the future without the need to submit a new version of your app to
  4. the store.

翻译成中文的意思就是,Bitcode是被编译程序的一种中间形式的代码。包含Bitcode配置的应用将在App Store上被编译和链接。Bitcode允许苹果在后期重新优化我们应用的二进制文件,而不需要我们重新提交一个版本到App Store上。

[cpp] view plaincopy

  1. Note: For iOS apps, bitcode is the default, but optional. If you provide bitcode, all apps and
  2. frameworks in the app bundle need to include bitcode. For watchOS apps, bitcode is required.

翻译成中文的意思就是,如果用Xcode7创建的app默认是包含有bitcode,但是是可以选择的。如果,我们的app包含了bitcode,我们工程中所有的第三方sdk必须也得支持bitcode,否则的话,就会报错误的。错误如下:

解决这个错误,有两种方案:

方案一:把不支持Bitcode的SDK给移除掉,等待第三方更新SDK。而目前大部分社交平台的SDK并不支持Bitcode。

方案二:把Bitcode给关闭掉,方法如下:

那么使用bitcode会给我们带来什么好处呢?苹果为什么要引入bitcode呢?其实引入bitcode的主要作用是给app瘦身,官方解释如下:

[cpp] view plaincopy

  1. Slicing is the process of creating and delivering variants of the app bundle for different target
  2. devices. A variant contains only the executable architecture and resources that are needed for the
  3. target device. You continue to develop and upload full versions of your app to iTunes Connect. The
  4. App Store will create and deliver different variants based on the devices your app supports. Image
  5. resources are sliced according to their resolution and device family. GPU resources are sliced
  6. according to device capabilities. When the user installs an app, a variant for the user’s device is
  7. downloaded and installed.
  8. Xcode simulates slicing during development so you can create and test variants locally. Xcode slices
  9. your app when you build and run your app on a device. When you create an archive, Xcode includes the
  10. full version of your app but allows you to export variants from the archive.

当前app的打包方式是把适配兼容多个设备的执行文件与资源文件合并成一个文件,上传和下载的文件则包含了所有的这些文件,导致占用较多的存储空间。

app瘦身就是让iOS设备在安装、更新以及运行app等场景中仅下载所需的资源,从而节省设备的存储空间。通过下面这张图,可以让我们很容易明白其中的原理

根据官方的解释,主要有以下三个方面:

1、Slicing

当把app打包上传到AppStore的时候,服务器会自动对包切割为不同的应用变体,当用户下载安装包的时候,系统会根据设备型号下载对应的应用变体。如上图所示。

2、Bitcode

开启bitcode编译后,可以让开发者上传app只需要上传中间二进制文件,而非最终的可执行二进制文件。在用户下载app之前,AppStore会自动编译中间二进制文件,从而生成可执行的二进制文件。

3、On-Demand Resources

所需资源是指开发者对资源添加标签上传后,系统会根据app运行的情况,动态下载并加载所需资源,如果存储空间不足时,自动删除这些资源。

三:Scheme白名单

从iOS9.0后,涉及到平台客户端的跳转,系统会自动到info.plist下检查是否设置Scheme。如果没有做相应的配置,就无法跳转到相应的客户端。因此如果客户端集成有分享与授权,需要配置Scheme白名单。

解决方案:

(1)、在info.plist增加key:LSApplicationQueriesSchemes,类型为NSArray。

(2)、添加需要支持的白名单,类型为String。

新浪微博白名单:sinaweibo、sinaweibohd、sinaweibosso、sinaweibohdsso、weibosdk、weibosdk2.5。

微信白名单:wechat、weixin。

支付宝白名单:alipay、alipayshare。

QQ与QQ空间白名单:mqzoneopensdk、mqzoneopensdkapi、mqzoneopensdkapi19、mqzoneopensdkapiV2、mqqOpensdkSSoLogin、mqqopensdkapiV2、mqqopensdkapiV3、wtloginmqq2、mqqapi、mqqwpa、mqzone、mqq。

另外,如果应用使用了检测是否安装了某款app,我们会调用canOpenURL, 如果url不在白名单中,即使手机上有这款app,也会返回NO。

补充:在使用sharesdk进行分享的时候,如果你设置有微信、QQ、QQ空间分享,并且你也把相应的白名单给添加进去了,但是如果你手机上没有装QQ的时候,也是不会出现分享到QQ的选项。

四:iPad适配Slide Over和Split View

若想适配multi tasking特性,建议不使用纯代码,改用storyboard、xib的形式。

补充,本文所说的都是iOS9.0SDK的新特性,如果你的app版本是基于iOS8.X、iOS7.X,并不受iOS9.0新特性约束。也就是说Xcode7给iOS8.X打设备包不需要白名单也能调用canOpenURL,但是Xcode7给iOS9.X打包则需要,Xcode7和iOS9缺一不可。

时间: 2024-10-17 16:02:38

iOS9中如何适配http,Bitcode,设置sina,qq,weChat配置Scheme白名单的相关文章

两种方法设置nginx并发限制下面的白名单策略

前言: 今天,公司主站突然出现IDE创建应用没反应的问题,经过预发布环境.非代理环境下面的服务测试,均没有问题,定位问题出现在前端.而我们前端有两层代理,一是青松抗D系统,一是我们自己的nginx代理系统.通过web页面测试发现控制台曝出下面的错误: 503 Service Temporarily Unavailable 那么可以断定的确是nginx这一层出现了问题.想想以前的nginx的配置修改及青松系统的接入,找到如下原因: 1. nginx设置单个IP的访问次数: limit_req_zo

适配iOS9遇到的一些问题_Scheme白名单_ Bitcode及解决办法

升级Xcode7 运行项目发现报错如下: 1.Scheme白名单问题 -canOpenURL: failed for URL: "weixin://app/wxdaae92a9cfe5d54c/" - error: "This app is not allowed to query for scheme weixin" 搜索后得知 近期苹果公司iOS 9系统策略更新,限制了http协议的访问,此外应用需要在"Info.plist"中将要使用的UR

项目适配iOS9遇到的一些问题及解决办法 ,以及URL 白名单配置方法

1.网络请求报错.升级Xcode 7.0发现网络访问失败.输出错误信息 The resource could not be loaded because the App Transport Security policy requires the use of a secure connection. 原因:iOS9引入了新特性App Transport Security (ATS).详情:App Transport Security (ATS)新特性要求App内访问的网络必须使用HTTPS协议

iOS9适配 之 关于info.plist 第三方登录 添加URL Schemes白名单

近期苹果公司iOS 9系统策略更新,限制了http协议的访问,此外应用需要在“Info.plist”中将要使用的URL Schemes列为白名单,才可正常检查其他应用是否安装. 受此影响,当你的应用在iOS 9中需要使用 QQ/QQ空间/支付宝/微信SDK 的相关能力(分享.收藏.支付.登录等)时,需要在“Info.plist”里增加如下代码: <key>LSApplicationQueriesSchemes</key> <array> <!-- 微信 URL S

iOS9 URL Schme 白名单

原文地址: https://github.com/ChenYilong/iOS9AdaptationTips WWDC 2015 Session 703: "Privacy and Your App( 时间在30:18左右)关于 URL scheme 的介绍,指出: 也就是说:在iOS9中,如果使用 canOpenURL: 方法,该方法所涉及到的 URL scheme 必须在"Info.plist"中将它们列为白名单,否则不能使用.key叫做LSApplicationQuer

云展网教程 | 如何设置邮箱白名单?

为保证您能正常接收云展网所发邮件,可在邮箱中将[email protected]设置为邮箱白名单,具体设置方法如下:1. 网易邮箱2. QQ 邮箱3. Gmail邮箱4. Hotmail邮箱5. 新浪邮箱6. 雅虎邮箱7. 搜狐邮箱8. 139 邮箱9. 其他邮箱 网易邮箱设置第一步:打开邮箱,点击网页右上端的设置 第二步:点击高级选项中的白名单 第三步:点击添加白名单按钮 第四步:在框内输入"[email protected],然后点击确定按钮 QQ 邮箱设置第一步:打开邮箱,点击网页右上角的

iOS白名单设置

在做分享.支付的时候需要跳转到对应的app,这里有需要设置的白名单列表<key>LSApplicationQueriesSchemes</key> <array> <!-- 微信 URL Scheme 白名单--> <string>wechat</string> <string>weixin</string> <!-- 新浪微博 URL Scheme 白名单--> <string>sin

关于iOS9中的App Transport Security相关说明及适配

iOS9中新增App Transport Security(简称ATS)特性, 主要使到原来请求的时候用到的HTTP,都转向TLS1.2协议进行传输.这也意味着所有的HTTP协议都强制使用了HTTPS协议进行传输.原文如下: App Transport Security App Transport Security (ATS) enforces best practices in the secure connections between an app and its back end. AT

关于iOS9中的App Transport Security相关说明及适配(转)

原文:http://my.oschina.net/vimfung/blog/494687 iOS9中新增App Transport Security(简称ATS)特性, 主要使到原来请求的时候用到的HTTP,都转向TLS1.2协议进行传输.这也意味着所有的HTTP协议都强制使用了HTTPS协议进行传输.原文如下: App Transport Security App Transport Security (ATS) enforces best practices in the secure co