我正在尝试在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);
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。