ios - CFNetwork SSLHandshake iOS 9 失败

标签 ios ssl nsurlconnection ios9

使用 iOS 9 beta 1 的人遇到过这个问题吗?

我使用标准 NSURLConnection 连接到网络服务,一旦调用网络服务,我就会收到以下错误。这目前在 iOS 8.3 中有效

可能是测试版错误?任何想法或想法都会很棒!我在 iOS 9 开发的早期就知道了

这是完整的错误:

CFNetwork SSLHandshake failed (-9824) NSURLSession/NSURLConnection HTTP load failed (kCFStreamErrorDomainSSL, -9824)

 NSURLRequest * urlRequest = [NSURLRequest requestWithURL:[NSURL URLWithString:@"https://mywebserviceurl"]];
        NSURLResponse * response = nil;
        NSError * error = nil;
        NSData * data = [NSURLConnection sendSynchronousRequest:urlRequest
                                                  returningResponse:&response
                                                              error:&error];

最佳答案

iOS 9 和 OSX 10.11 要求您计划从中请求数据的所有主机使用 TLSv1.2 SSL,除非您在应用程序的 Info.plist 文件中指定异常(exception)域。

Info.plist 配置的语法如下所示:

<key>NSAppTransportSecurity</key>
<dict>
  <key>NSExceptionDomains</key>
  <dict>
    <key>yourserver.com</key>
    <dict>
      <!--Include to allow subdomains-->
      <key>NSIncludesSubdomains</key>
      <true/>
      <!--Include to allow insecure HTTP requests-->
      <key>NSExceptionAllowsInsecureHTTPLoads</key>
      <true/>
      <!--Include to specify minimum TLS version-->
      <key>NSExceptionMinimumTLSVersion</key>
      <string>TLSv1.1</string>
    </dict>
  </dict>
</dict>

如果您的应用程序(例如第三方网络浏览器)需要连接到任意主机,您可以这样配置:

<key>NSAppTransportSecurity</key>
<dict>
    <!--Connect to anything (this is probably BAD)-->
    <key>NSAllowsArbitraryLoads</key>
    <true/>
</dict>

如果您必须这样做,最好更新您的服务器以使用 TLSv1.2 和 SSL(如果它们尚未这样做)。这应被视为临时解决方法。

截至今天,预发布文档没有以任何特定方式提及任何这些配置选项。完成后,我将更新答案以链接到相关文档。

关于ios - CFNetwork SSLHandshake iOS 9 失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30720813/

相关文章:

iOS 11 Safari HTML - 禁用 "Smart Punctuation"?

ios - 在 View 中创建对中心标签的约束

ssl - 如何通过端口 8883 使 TLS 在 MQTT 中工作?

apache - 在 AWS EBS 单实例 (Tomcat) 上安装 SSL 证书

ssl - 证书错误DLG_FLAGS_SEC_CERT_CN_INVALID

objective-c - sendSynchronousRequest 使用安装在 Mac OS X keychain for Mac 上的自签名证书

objective-c - 管理多个异步 NSURLConnection 连接

ios - 缓存不适用于自定义 NSURLProtocol

ios - UIView block 动画更新间隔

ios - NSString rangeOfString 执行缓慢