2017-02-02 8 views
4

В настоящее время я пытаюсь загрузить изображение на amazon с предварительно подписанным URL-адресом.Загрузка изображения с помощью Alamofire с помощью PUT

Как это работает, я делаю запрос GET для получения предварительно подписанного URL-адреса и запроса PUT для загрузки изображения с использованием URL-адреса, возвращаемого из запроса GET.

Эти два правила: Content-Type должен быть image \ jpeg, а методы http должны быть PUT.

Итак, в настоящее время мой код загрузки возвращает 200, но amazon отклоняет данные.

Вот мой код:

Фактический адрес возвращается для загрузки составляет: https://mimik-apps-channel.s3-us-west-2.amazonaws.com/profiles/2312528782074206653.jpg?X-Amz-Expires=3600&X-Amz-Algorithm=AWS4-HMAC-SHA256&X-Amz-Credential=AKIAJ36SCZW7WGBAW7CQ/20170202/us-west-2/s3/aws4_request&X-Amz-Date=20170202T102202Z&X-Amz-SignedHeaders=host&X-Amz-Signature=007ad8694fe1ed83b08d4890f17b9985e169f7ab8fcd7b0d648a383c69ebc748

    var headers = Alamofire.SessionManager.defaultHTTPHeaders 
        headers["Content-Type"] = "image/jpeg" 
        let URL = try! URLRequest(url: url, method: .put, headers: headers) 

        Alamofire.upload(multipartFormData: { (multipartFormData) in 
         let compressionQuality: CGFloat = 0.8 
         guard let imageData = UIImageJPEGRepresentation(image, compressionQuality) else { 
          print("Unable to get JPEG representation for image \(image)") 

          return 
         } 

         multipartFormData.append(imageData, withName: "image.jpg", mimeType: "image/jpeg") 
         // code 
        }, with: URL, encodingCompletion: { (result) in 
         switch result { 
         case .success(let upload, _, _): 
          upload.responseJSON { response in 
           print("SUCCESS -> \(response.request?.allHTTPHeaderFields)") 

          } 

         case .failure(let encodingError): 
          print(encodingError) 
         } 
        }) 

Я подозреваю, что когда я печатаю заголовки HTTP Content-Type всегда показывает многослойную/форм-данных а не образ/jpeg, который мне нужен, но в настоящее время я потерял, что делать, чтобы решить эту проблему.

ответ

3

Я на самом деле в последнее время были одни и те же требования (за исключением мне нужно было PNG вместо JPG).

Вот как вы это делаете.

let compressionQuality: CGFloat = 0.8 
guard let imageData = UIImageJPEGRepresentation(image, compressionQuality) else { 
    print("Unable to get JPEG representation for image \(image)") 
    return 
} 

let headers = [ 
    "Content-Type": "image/jpeg" 
] 

// presignedUrl is a String 

Alamofire.upload(imageData, to: presignedUrl, method: .put, headers: headers) 
    .responseData { 
     response in 

     guard let httpResponse = response.response else { 
      print("Something went wrong uploading") 
      return 
     } 

     let publicUrl = presignedUrl.components(separatedBy: "?")[0] 
    } 
1

Вы изменили свои возможности, чтобы предоставлять фоновые сервисы?

enter image description here

то, что работал со мной:

let imageData = UIImageJPEGRepresentation(image , 0.7) 

     Alamofire.upload(imageData!, to: url, method: .put, headers: nil).responseJSON(completionHandler: { (response) in 
       debugPrint(response) 
      })