iOS9 HTTP 不能正常使用的解决办法
2016-03-11 14:34
519 查看
今天升级
输出错误信息
Google后查证,iOS9引入了新特性
Transport Security (ATS)
新特性要求App内访问的网络必须使用
但是现在公司的项目使用的是
在Info.plist中添加
在
在Filter中搜索
按照上面提到的方式添加信息,正确的修改会看到下图这个样子,注意类型
fault 页面上直接复制,经常会多一个出空格!
注意⚠️,单元测试下面也有一个
上面介绍的方法虽然解决了网络访问的问题,但是苹果提供的安全保障也被关闭了。
不过,按照国内的现状,关闭这个限制也许是更实际的做法。
至于原因就太多了,第三方SDK(几乎都是访问
如果你的App没有受到这些原因的限制,还是更建议你增加
请大家根据项目的实际情况作调整。
出于安全考虑我们提倡使用
@banxi1988 补充了配置的方法
对于实在不支持
添加例外的方式也很简单:
左键
然后添加类似如下的配置:
根据自己需要的域名修改, NSIncludeSubdomains 顾名思义是包括子域的意思。
App
Transport Security support aka apps on iOS 9 don't work #4560
711_networking_with_nsurlsession.pdf
苹果正在加大应用安全的管控,这个举措可以看出苹果对信息安全的重视,也暴露出大部分应用传输数据时都是未经过加密的,或使用私有方式加密,以至于苹果开始对开发者提出要求。
私有加密虽然一定程度上是安全的,但是终究不是一个长久之计。全世界这么多安全专家在维护
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
看到很多同学修改后还是不能用添加一下截图:
在Filter中搜索Info.plist,选择
Info.plist进行编辑
按照上面提到的方式添加信息,正确的修改会看到下图这个样子,注意类型
NSAppTransportSecurity为
Dictionary,
NSAllowsArbitraryLoads为
Boolean,复制粘贴的时候,不要多了空格,segment
fault 页面上直接复制,经常会多一个出空格!
注意⚠️,单元测试下面也有一个
Info.plist,修改那个文件是没有作用的!
补充说明
上面介绍的方法虽然解决了网络访问的问题,但是苹果提供的安全保障也被关闭了。不过,按照国内的现状,关闭这个限制也许是更实际的做法。
至于原因就太多了,第三方SDK(几乎都是访问
HTTP),合作伙伴接入(不能要求它们一定要支持HTTPS)。
如果你的App没有受到这些原因的限制,还是更建议你增加
HTTPS支持,而不是关闭限制。
请大家根据项目的实际情况作调整。
出于安全考虑我们提倡使用
HTTPS,退而求其次,优先考虑使用
例外:将允许访问的域加入到配置列表中
@banxi1988 补充了配置的方法
对于实在不支持
HTTPS的应该首先考虑添加
例外
添加例外的方式也很简单:
左键
Info.plist选择
open with source code
然后添加类似如下的配置:
<key>NSAppTransportSecurity</key> <dict> <key>NSExceptionDomains</key> <dict> <key>qq.com</key> <dict> <key>NSIncludesSubdomains</key> <true/> </dict> <key>sina.com.cn</key> <dict> <key>NSIncludesSubdomains</key> <true/> </dict> </dict> </dict>
根据自己需要的域名修改, NSIncludeSubdomains 顾名思义是包括子域的意思。
参考:
AppTransport Security support aka apps on iOS 9 don't work #4560
711_networking_with_nsurlsession.pdf
总结:
苹果正在加大应用安全的管控,这个举措可以看出苹果对信息安全的重视,也暴露出大部分应用传输数据时都是未经过加密的,或使用私有方式加密,以至于苹果开始对开发者提出要求。私有加密虽然一定程度上是安全的,但是终究不是一个长久之计。全世界这么多安全专家在维护
HTTPS安全,早日使用
HTTPS确保信息安全才是王道!也省去了私有加密协议的安全隐患!
相关文章推荐
- iOS开发工具——网络封包分析工具Charles
- nginx http2配置
- 多层感知器 - Multilayer Perceptron --(Back-propagation Algorithm - 反馈神经网络)
- httpClient多线程问题
- Http Get和Post区别
- Android笔记--Android Studio 引用第三方开源类okhttp、gson库时的打包混淆
- Ubuntu下HTTPS配置
- 内存泄漏检测http://www.cnblogs.com/yixiaoyang/archive/2010/12/10/1902255.html
- Valgrind确实是强大的工具http://www.cnblogs.com/nicebear/archive/2012/05/05/2485054.html
- python 网络编程第一章
- HTTP和HTTPS的区别(转)
- C/C++的内存泄漏检测工具Valgrind memcheck的使用经历 http://www.cnblogs.com/lanxuezaipiao/p/3604533.html
- HTTP协议基础
- HTTPS证书安装 - SSL certificate from Godaddy 安装到Ubuntu上的Apache (精简步骤)
- Android 网络通信框架Volley简介(Google IO 2013)
- HttpWatch和jmeter的一次性能测试
- iOS网络开发工具集----字符串操作和时间操作
- HttpClient使用详解
- YTKNetwork 使用高级教程
- YTKNetwork 使用基础教程