Swift alamofire中的证书固定为wrog

Swift alamofire中的证书固定为wrog,swift,alamofire,certificate-pinning,Swift,Alamofire,Certificate Pinning,我想在Alamofire中使用证书固定。 这是我的密码: // Set up certificates let pathToCert = Bundle.main.path(forResource: cert, ofType: "der") let localCertificate = NSData(contentsOfFile: pathToCert!) let certificates = [Se

我想在
Alamofire
中使用证书固定。 这是我的密码:


            // Set up certificates
            let pathToCert = Bundle.main.path(forResource: cert, ofType: "der")
            let localCertificate = NSData(contentsOfFile: pathToCert!)
            let certificates = [SecCertificateCreateWithData(nil, localCertificate!)!]

            // Configure the trust policy manager
            let serverTrustPolicy = ServerTrustPolicy.pinCertificates(
                certificates: ServerTrustPolicy.certificates(),
                validateCertificateChain: false,
                validateHost: true)

            let serverTrustPolicies = ["hostname": serverTrustPolicy]
            let serverTrustPolicyManager = ServerTrustPolicyManager(policies: serverTrustPolicies)

            let sessionManager = SessionManager(configuration: URLSessionConfiguration.default,serverTrustPolicyManager: serverTrustPolicyManager)


            sessionManager
                .request()...
这是我的信息。plist->

我得到了这个错误:
加载失败,错误为Domain=nsurerrordomain code=-999“已取消”

我找了很多,但找不到任何东西来解决我的问题。
我使用
open ssl

.crt
文件转换为
.der
文件,除了在请求完成之前对
SessionManager
进行身份验证时看到此错误之外,正如这里的问题一样,当Alamofire 4中的证书固定失败时,您也会看到此错误。在这两种情况下,更新到Alamofire 5都会给您带来更好的错误。

使用Mapbox API下载地图分幅时,我会得到一个类似的“错误”代码-999。对我来说,这只是意味着有时API会取消它发出的一些请求。它看起来像一个错误,但实际上它只是一个操作,不再需要,已经被自动取消。你的代码运行正常吗?@Magnas我如何测试它?没问题。这个问题对如何保留
sessionManager
提供了一些建议,可能会对您有所帮助。谢谢,问题是会话管理器取消了@Magnas的分配