该服务器的证书对于 swift 3 上的自签名证书无效

2024-04-03

我正在使用 swift 3 并第一次访问网络服务。我的 Web 服务通过 HTTPS 运行,我想在适当的加密情况下进行测试。

到目前为止,这是我的代码:

    let config = URLSessionConfiguration.default // Session Configuration
    let session = URLSession(configuration: config) // Load configuration into Session
    let url = URL(string: webService.getLoginUrl())!

    let task = session.dataTask(with: url, completionHandler: {
        (data, response, error) in

        if error == nil {
            do {
                if let json =
                    try JSONSerialization.jsonObject(with: data!, options: .allowFragments) as? [String: Any]{
                    //Implement your logic
                    print(json)
                }
            } catch {
                print("error in JSONSerialization")
            }
        } else {
            print(error!.localizedDescription)
        }

    })
    task.resume()

当我对自签名的测试服务器运行此命令时,我得到:

The certificate for this server is invalid. You might be connecting to a server that is pretending to be “10.0.0.51” which could put your confidential information at risk.

所以我想做的是在测试时接受所有证书,但不在生产中接受。

我发现了几个网站,例如:

http://www.byteblocks.com/Post/Use-self-signed-SSL-certificate-in-iOS-application http://www.byteblocks.com/Post/Use-self-signed-SSL-certificate-in-iOS-application https://github.com/socketio/socket.io-client-swift/issues/326 https://github.com/socketio/socket.io-client-swift/issues/326

但这些似乎早于 swift 3。

我该如何解决这个问题?


经过大量研究,我了解了委托如何在 swift 3 中使用 URLSession 对象。太多内容无法发布链接,但最终,这是最有帮助的:https://gist.github.com/stinger/420107a71a02995c312036eb7919e9f9 https://gist.github.com/stinger/420107a71a02995c312036eb7919e9f9

因此,为了解决这个问题,我从 URLSessionDelegate 继承了我的类,然后添加了以下函数:

func urlSession(_ session: URLSession, didReceive challenge: URLAuthenticationChallenge, completionHandler: @escaping (URLSession.AuthChallengeDisposition, URLCredential?) -> Void) {

    //accept all certs when testing, perform default handling otherwise
    if webService.isTesting() {
        print("Accepting cert as always")
        completionHandler(.useCredential, URLCredential(trust: challenge.protectionSpace.serverTrust!))
    }
    else {
        print("Using default handling")
        completionHandler(.performDefaultHandling, URLCredential(trust: challenge.protectionSpace.serverTrust!))
    }
}

isTesting() 调用确定我是否正在使用测试服务器,然后如果我们处于测试模式,我们将接受所有证书。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

该服务器的证书对于 swift 3 上的自签名证书无效 的相关文章

随机推荐