【问题标题】:Log alamofire upload image request and response记录alamofire上传图片请求和响应
【发布时间】:2019-08-27 06:45:39
【问题描述】:

我知道这个问题有很多,但我找不到与上传相关的确切问题。我使用alamofire 进行HTTP 调用。 我正在尝试将图像上传到 Amazon S3 并收到错误,想要记录请求和响应以查看究竟是什么问题。

除了 Alamofire.upload 之外,我的所有请求都在记录。我为请求添加了一个扩展,并且 Aramofire.request 正在记录,现在我的问题是也要记录 Alamofire.upload。

例如,我正在尝试记录以下示例的请求和响应。

Alamofire.upload(multipartFormData: { (multipartFormData) in
    for (key, value) in params {
        multipartFormData.append(value.data(using: String.Encoding.utf8, allowLossyConversion: false)!, withName: key)
    }
    if image != nil {
        if let imgData = UIImageJPEGRepresentation(image!, 0.8) {
            multipartFormData.append(imgData, withName: "file", fileName: "file.jpg", mimeType: "image/jpeg")
        }
    }
   }, to: "amazon.s3.URL")

【问题讨论】:

    标签: swift amazon-s3 alamofire


    【解决方案1】:

    在深入研究 SessionManager 类后,我发现了如何记录上传请求和响应。 我重写了上传功能。

    这是我的例子

    class AlamofireManager: SessionManager {
    
        override func upload(_ data: Data, with urlRequest: URLRequestConvertible) -> UploadRequest {
            let request = super.upload(data, with: urlRequest)
    
            print("Request: \(request.debugDescription)")
    
            print("Response: \(request.response.data)")
    
            return request
        }
    }
    

    【讨论】:

      【解决方案2】:

      你也可以使用这个 pod https://github.com/konkab/AlamofireNetworkActivityLogger 并且你可以在 applicationDidLaunch.. 中调用它,它会记录一切非常好。

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 2014-12-31
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2019-01-10
        • 2023-04-02
        • 2015-06-20
        相关资源
        最近更新 更多