【问题标题】:certificate pinning in alamofire is wrogalamofire 中的证书固定是错误的
【发布时间】:2019-11-23 11:07:11
【问题描述】:

我想在 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()...

这是我的 info.plist ->

我得到这个错误: load failed with error Error Domain=NSURLErrorDomain Code=-999 "cancelled"

我搜索了很多,但找不到任何可以解决我的问题的东西。 我使用 open ssl 将我的 .crt 文件转换为 .der 文件。

【问题讨论】:

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

标签: swift alamofire certificate-pinning


【解决方案1】:

除了在请求完成之前SessionManager 被取消初始化时看到此错误(正如这里的问题),当您在 Alamofire 4 中证书固定失败时也会看到此错误。更新到 Alamofire 5 将提供在这两种情况下,你的错误要好得多。

【讨论】:

    猜你喜欢
    • 2016-04-09
    • 1970-01-01
    • 2023-03-04
    • 1970-01-01
    • 2021-09-14
    • 1970-01-01
    • 1970-01-01
    • 2017-12-06
    • 2017-11-01
    相关资源
    最近更新 更多