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的分配