iOS9 HTTP 不能正常使用的解决办法

今天升级Xcode 7.0 bata发现网络访问失败。
输出错误信息html

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)ios

新特性要求App内访问的网络必须使用HTTPS协议。
可是如今公司的项目使用的是HTTP协议,使用私有加密方式保证数据安全。如今也不能立刻改为HTTPS协议传输。git

最终找到如下解决办法:

  1. 在Info.plist中添加NSAppTransportSecurity类型Dictionary
  2. NSAppTransportSecurity下添加NSAllowsArbitraryLoads类型Boolean,值设为YES

参考:

总结:

苹果正在加大应用安全的管控,这个举措能够看出苹果对信息安全的重视,也暴露出大部分应用传输数据时都是未通过加密的,或使用私有方式加密,以致于苹果开始对开发者提出要求。
私有加密虽然必定程度上是安全的,可是终究不是一个长久之计。全世界这么多安全专家在维护HTTPS安全,早日使用HTTPS确保信息安全才是王道!也省去了私有加密协议的安全隐患!github

相关文章
相关标签/搜索