ios - 具有Alamofire下载功能的JWT认证

标签 ios swift jwt alamofire express-jwt

感谢 Alamofire,我正在尝试下载一个 zip 文件并使用 JWT token 身份验证从服务器保存它.下载在没有 token 身份验证的情况下运行良好,文件已成功保存。当我激活服务器端身份验证(使用 Passport.js 和 NodeJS)时,我总是收到 401。我使用 sessionManager 适配器函数将 token 附加到 header 。其他请求(发布,使用 sessionManager.request(..) 获取)与此身份验证机制配合良好。

问题是:能否修改Alamofire下载函数的header?如果是怎么办?

感谢任何建议

func getZip(){

    let sessionManager = Alamofire.SessionManager.default
    let authHandler = JWTAccessTokenAdapter(accessToken: Auth.getAccessToken())

    sessionManager.retrier = authHandler
    sessionManager.adapter = authHandler


    let downloadUrl: String = Auth.getApiEndpoint() + "get_zip"
    let destinationPath: DownloadRequest.DownloadFileDestination = { _, _ in
        let documentsURL = FileManager.default.urls(for: .documentDirectory, in: .userDomainMask)[0];
        let fileURL = documentsURL.appendingPathComponent("myZip.zip")
        return (fileURL, [.removePreviousFile, .createIntermediateDirectories])
    }


    sessionManager.download(downloadUrl, method: .get,  encoding: URLEncoding.httpBody, to: destinationPath)
        .downloadProgress { progress in
            print(">> Zip Download Progress: \(progress.fractionCompleted)")
        }
        .responseData { response in
            switch response.result{
            case .success:
                if response.destinationURL != nil, let filePath = response.destinationURL?.absoluteString {
                    print("success & filepath : \(filePath)")
                    completionHandler(filePath, true)
                }
                break
            case .failure:
                print("faillure")
                completionHandler("", false)
                break
            }

        }
    } 
}

JWT 适配器:

class JWTAccessTokenAdapter: RequestAdapter {

     typealias JWT = String
     private var accessToken: JWT

     func adapt(_ urlRequest: URLRequest) throws -> URLRequest {
        var urlRequest = urlRequest

        if let urlString = urlRequest.url?.absoluteString, urlString.hasPrefix(Auth.getApiEndpoint()) {
        /// Set the Authorization header value using the access token.
           urlRequest.setValue(accessToken, forHTTPHeaderField: "Authorization")
        }

    return urlRequest

   }
}

输出:

response: SUCCESS: 12 bytes // (Unauthorized) -> Corrupted zip file

最佳答案

如果您的请求链中没有验证步骤,所有响应都将被视为成功。因此,请检查您的响应代码(或在 responseData 之前添加 .validate())并查看您的请求是否真的成功。此外,您可能需要仔细检查参数编码,尽管您似乎没有发送任何参数。

关于ios - 具有Alamofire下载功能的JWT认证,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53765060/

相关文章:

ios - 所有 Controller 上的快速播放器小部件

ios - 引用具有重用标识符的单元格

ios - 访问 UNNotificationRequest 对象的预定日期

ios - 如何使 Xcode 自动符合协议(protocol)

执行RFC7523

c# - Asp.Net Core 3 Identity - 来自浏览器的 JWT 中不存在自定义声明

jwt - Ed25519 的 alg 值?

ios - countDownTimer = 0 的 UIDatePicker 显示 "0 hours 1 min"

generics - 如何在 Swift 中调用不明确的泛型函数?

ios - 如何快速将按钮置于 Storyboard上方的桌面 View 中央?