我在Jetty 9.3服务器上配置了HTTP / 2,它有一个有效的证书和SSLLabs.com给它一个A级安全配置.
使用Chrome浏览器到https://example.com浏览加载了正确的响应,它还报告使用了“h2”(HTTP / 2“)协议.
但是当尝试使用NSURLConnection从iOS 9访问相同的URL时,我可以在请求日志中看到它使用了HTTP 1.1.如果我在我的服务器上禁用HTTP 1.1,请求将在iOS 9上失败(但仍然在Chrome上成功).
NSURLConnection代码 –
let url = NSURL(string: "https://example.com") request = NSURLRequest(URL: url,cachePolicy: NSURLRequestCachePolicy.ReloadIgnoringLocalCacheData,timeoutInterval: 10) connection = NSURLConnection(request: request,delegate: self,startImmediately: true)
服务器的ALPN调试输出 –
[S] ALPN protocols [spdy/3.1,spdy/3,http/1.1] received from client for 1e5e2487[SSLEngine[hostname=3.4.5.6 port=52090] SSL_NULL_WITH_NULL_NULL] [S] ALPN protocol 'http/1.1' selected for 1e5e2487[SSLEngine[hostname=3.4.5.6 port=52090] SSL_NULL_WITH_NULL_NULL]
在WWDC 2015中,据称iOS 9中的NSURLRequest支持HTTP / 2,但客户端应用声称支持spdy / 3.1,spdy / 3,http / 1.1,没有http / 2.没有设置NSAppTransportSecurity异常.
我尝试在运行应用程序的同一个iPhone模拟器上使用Safari连接到服务器,这次它工作并使用HTTP / 2,这里是ALPN调试输出 –
[S] ALPN protocols [h2,h2-16,h2-15,h2-14,spdy/3.1,http/1.1] received from client for 7b50217d[SSLEngine[hostname=3.4.5.6 port=52247] SSL_NULL_WITH_NULL_NULL] [S] ALPN protocol 'h2' selected for 7b50217d[SSLEngine[hostname=3.4.5.6 port=52247] SSL_NULL_WITH_NULL_NULL]
任何想法为什么它不在应用程序内使用HTTP / 2?