我正在尝试在iOS 8的WKWebView中加载具有自签名证书的HTTPS网址,并保持失败. UIWebView使用的解决方法(使用NSUrlRequest中的setAllowsAnyHTTPSCertificate)似乎不起作用.有没有人知道任何解决方法?
我不需要一个适用于AppStore的解决方案,因为我只需要在开发阶段访问自签名的证书站点,而不是在生产环境中使用,但是开发和测试服务器实例确实是一个问题.
先谢谢你.
解决方法
这是在iOS 9中修复的! WKWebView终于在WKNavigationDelegate上调用了webView(_:didReceiveAuthenticationChallenge:completionHandler :).不幸的是,如果您在iOS 8设备上运行
@L_301_0@ 7内置的代码(至少不在我的初始测试中),则无法运行.
在下面的例子中,我并没有对证书做任何事情,只是让它通过,而不进行任何进一步的验证(显然是生产代码的坏计划).有关他们希望在这里做什么的更多细节,请参见Apple’s docs(清单3).
迅速:
func webView(webView: WKWebView,didReceiveAuthenticationChallenge challenge: NSURLAuthenticationChallenge,completionHandler: (NSURLSessionAuthChallengeDisposition,NSURLCredential?) -> Void) { let cred = NSURLCredential.init(forTrust: challenge.protectionSpace.serverTrust!) completionHandler(.UseCredential,cred) }
Swift 3:
let cred = URLCredential(trust: challenge.protectionSpace.serverTrust!) completionHandler(.useCredential,cred)
Objective-C的
NSURLCredential * credential = [[NSURLCredential alloc] initWithTrust:[challenge protectionSpace].serverTrust]; completionHandler(NSURLSessionAuthChallengeUseCredential,credential);