Как загрузить несколько изображений в массив под одним и тем же именем ключа в Swift 4 без использования Alamofire - PullRequest
0 голосов
/ 06 ноября 2019

Получите код для загрузки одного изображения, но не можете загрузить несколько изображений в массив под одним и тем же ключом.

В НИЖЕ КОДЕ, он отлично работает, когда я отправляю одно изображение на сервер. -> Я хочу найти ответ для нескольких изображений в массиве без использования alamofire или другой сторонней библиотеки.

      func imageUploadRequest(IMAGE_ARRAY: [UIImage] , uploadUrl: NSURL) {

        myloader.showLoader(controller: self)
      let param = ["title":"ds","category_id":"5","description":"gdfjghjdsfgksd","user_id":"66","color":"red"]

        let request = NSMutableURLRequest(url:uploadUrl as URL)
        request.httpMethod = "POST"
        let boundary = generateBoundaryString()
        request.setValue("multipart/form-data; boundary=\(boundary)", forHTTPHeaderField: "Content-Type")

        //let imageData = UIImageJPEGRepresentation(imageView.imageOrientation, 0.1)
        for item in IMAGE_ARRAY
        {
            let imageData = item.jpegData(compressionQuality: 0.01)
            if(imageData==nil)  { return; }

            request.httpBody = createBodyWithParameters(parameters: param as [String : Any], filePathKey: "files[]", cv : imageData! as NSData, boundary: boundary) as Data
        }

        // myActivityIndicator.startAnimating();

        let task =  URLSession.shared.dataTask(with: request as URLRequest,
                                               completionHandler: {
                                                (data, response, error) -> Void in
                                                if let data = data {
                                                    DispatchQueue.main.async { // Update UI
                                                        self.myloader.removeLoader(controller: self)
                                                        let decoder = JSONDecoder()

                                                        let obj = try! decoder.decode(GetResponse_Otp.self, from: data)


                                                    }
                                                }
        })
        task.resume()
    }

    func createBodyWithParameters(parameters: [String: Any]?, filePathKey: String?, cv: NSData, boundary: String) -> NSData {
        let body = NSMutableData();

        if parameters != nil {
            for (key, value) in parameters! {
                body.appendString("--\(boundary)\r\n")
                body.appendString("Content-Disposition: form-data; name=\"\(key)\"\r\n\r\n")
                body.appendString("\(value)\r\n")
            }
        }

        let filename = "\(Date().timeIntervalSince1970).jpeg"
        let mimetype = "image/png"

        body.appendString("--\(boundary)\r\n")
        body.appendString("Content-Disposition: form-data; name=\"\(filePathKey!)\"; filename=\"\(filename)\"\r\n")
        body.appendString("Content-Type: \(mimetype)\r\n\r\n")
        body.append(cv as Data)
        body.appendString("\r\n")

        body.appendString("--\(boundary)--\r\n")

        return body
    }

    func generateBoundaryString() -> String {
        return "Boundary-\(NSUUID().uuidString)"
    }
    // extension for impage uploading
}

Ответы [ 2 ]

0 голосов
/ 07 ноября 2019
func imageUploadRequest(ARRAY_OF_IMAGES: [ANY] , uploadUrl: NSURL) {

     myloader.showLoader(controller: self)
     let param = ["user_id":fetchString(key: "userId"), "career_level":UnwarppingValue(value: btnCarrer.title(for: .normal)),"education":UnwarppingValue(value: btnEducation.title(for: .normal)),"cur_location":txtFldLocation.text!,"cur_position":txtFldCurrentPosition.text!,"cur_employee":txtFldCurrentEmployee.text!,"experience": UnwarppingValue(value: btnExperience.title(for: .normal)),"industry":UnwarppingValue(value: btnIndustry.title(for: .normal))] as [String : Any]

     let request = NSMutableURLRequest(url:uploadUrl as URL)
     request.httpMethod = "POST"
     let boundary = generateBoundaryString()
     request.setValue("multipart/form-data; boundary=\(boundary)", forHTTPHeaderField: "Content-Type")

     //let imageData = UIImageJPEGRepresentation(imageView.imageOrientation, 0.1)
     for item in IMAGE_ARRAY
     {
     let imageData = item.jpegData(compressionQuality: 0.01)
     if(imageData==nil)  { return; }

     request.httpBody = createBodyWithParameters(parameters: param as [String : Any], filePathKey: "KEY_NAME[]", cv : imageData! as NSData, boundary: boundary) as Data
     }

     // myActivityIndicator.startAnimating();

     let task =  URLSession.shared.dataTask(with: request as URLRequest,
                                               completionHandler: {
                                                (data, response, error) -> Void in
             if let data = data {
                DispatchQueue.main.async { // Update UI
                     self.myloader.removeLoader(controller: self)
                     let decoder = JSONDecoder()

                     let obj = try! decoder.decode(GetResponse_ProfileOverViewDetails.self, from: data)

                     guard obj.response?.result == "1" else{
                        showToast(message: obj.response?.msg ?? "Something Went Wrong", vc: self, normalColor: false)
                        return
                     }

                     if let userPic = obj.response?.data?[0].pic {
                           saveStringInDefault(value: userPic, key: "userPic")
                     }else {
                         saveStringInDefault(value: "", key: "userPic")
                     }
                  showToast(message: obj.response?.msg ?? "Something Went Wrong", vc: self, normalColor: false)
             }
         }
       })task.resume()
    }

    func createBodyWithParameters(parameters: [String: Any]?, filePathKey: String?, cv: NSData, boundary: String) -> NSData {
        let body = NSMutableData();

        if parameters != nil {
            for (key, value) in parameters! {
                body.appendString(string: "--\(boundary)\r\n")
                body.appendString(string: "Content-Disposition: form-data; name=\"\(key)\"\r\n\r\n")
                body.appendString(string: "\(value)\r\n")
            }
        }

        let filename = HERE->(Date().timeIntervalSince1970).jpeg
        let mimetype = "image/png"

        body.appendString(string: "--\(boundary)\r\n")
        body.appendString(string: "Content-Disposition: form-data; name=\"\(filePathKey!)\"; filename=\"\(filename)\"\r\n")
        body.appendString(string: "Content-Type: \(mimetype)\r\n\r\n")
        body.append(cv as Data)
        body.appendString(string: "\r\n")

        body.appendString(string: "--\(boundary)--\r\n")

        return body
    }

    func generateBoundaryString() -> String {
        return "Boundary-\(NSUUID().uuidString)"
    }
    // extension for impage uploading
}

Проверьте, что я редактирую код прописными буквами.

0 голосов
/ 06 ноября 2019

Вам нужно изменить имя ключа на KEY_NAME [], добавить массив [] в ключ и убедиться, что каждый раз имя файла отличается или вы можете попробовать это тоже:

(Date().timeIntervalSince1970).jpeg

, чтобы убедиться, чточто имя меняется каждый раз.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...