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 – 在WKWebView中允许未经验证的ssl证书全部内容,希望文章能够帮你解决ios – 在WKWebView中允许未经验证的ssl证书所遇到的程序开发问题。

如果觉得来客网网站内容还不错,欢迎将来客网网站推荐给程序员好友。