ios – 在WKWebView中允许未经验证的ssl证书

前端之家收集整理的这篇文章主要介绍了ios – 在WKWebView中允许未经验证的ssl证书前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在尝试在iOS 8的WKWebView中加载具有自签名证书的HTTPS网址,并保持失败. UIWebView使用的解决方法(使用NSUrlRequest中的setAllowsAnyHTTPSCertificate)似乎不起作用.有没有人知道任何解决方法

我不需要一个适用于AppStore的解决方案,因为我只需要在开发阶段访问自签名的证书站点,而不是在生产环境中使用,但是开发和测试服务器实例确实是一个问题.

先谢谢你.

解决方法

这是在iOS 9中修复的! WKWebView终于在WKNavigationDelegate上调用了webView(_:didReceiveAuthenticationChallenge:completionHandler :).不幸的是,如果您在iOS 8设备上运行 Xcode 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);

猜你在找的iOS相关文章