今天升级 Xcode 7.0 bata,发现网络访问失败。
输出错误信息
The resource could not be loaded because the App Transport Security policy requires the use of a secure connection.
Google后查证,iOS9引入了新特性 App Transport Security (ATS) 。
详情: App Transport Security (ATS)
新特性要求App内访问的网络必须使用 HTTPS协议。但是现在公司的项目使用的是 HTTP协议,使用私有加密方式保证数据安全。现在也不能马上改成 HTTPS协议传输。
最终找到以下解决办法:
在Info.plist中添加 NSAppTransportSecurity 类型 Dictionary 。
在 NSAppTransportSecurity 下添加 NSAllowsArbitraryLoads 类型 Boolean, 值设为 YES
参考:
App Transport Security support aka apps on iOS 9 don't work #4560
711_networking_with_nsurlsession.pdf
总结:
苹果正在加大应用安全的管控,这个举措可以看出苹果对信息安全的重视,也暴露出大部分应用传输数据时都是未经过加密的,或使用私有方式加密,以至于苹果开始对开发者提出要求。
私有加密虽然一定程度上是安全的,但是终究不是一个长久之计。全世界这么多安全专家在维护 HTTPS安全,早日使用 HTTPS确保信息安全才是王道!也省去了私有加密协议的安全隐患!