#ios #swift #image #post
#iOS #swift #изображение #Публикация
Вопрос:
Я пытаюсь отправить UIImage в API, чтобы прочитать текст из этого UIImage, но получаю следующую ошибку: Кроме того, как мне напечатать URLRequest на консоли, чтобы увидеть, какие элементы в нем. Я также пробовал Alamofire, но проблема, похоже, в запросе, который не отправляется должным образом. Мы высоко ценим любой тип помощи.
Error:
AsSynchronous{
error = {
code = 400;
message = "Wrong request: No file sent in the request, please set the field 'files'";
requestId = "d9adb89b-cd67-48e4-7846-0aa4c78fc08e";
};
}
МОЙ КОД:
`func uploadImage(paramName: String, fileName: String, image: UIImage,apiKey:String) {
let boundary = UUID().uuidString
let urlRequest = NSMutableURLRequest(url: NSURL(string: "https://xxxxxxxxxxxxx")! as URL,
cachePolicy: .useProtocolCachePolicy,
timeoutInterval: 10.0)
urlRequest.httpMethod = "POST"
urlRequest.setValue("multipart/form-data; boundary=(boundary)", forHTTPHeaderField: "Content-Type")
let headers = [
"content-type": "multipart/form-data; boundary=----WebKitFormBoundary7MA4YWxkTrZu0gW",
"apikey": "yyyyyyyyyyyyyyyyy",
"cache-control": "no-cache",
"Postman-Token": "87b45036-1107-4db6-bf4d-7dc83314045b"
]
urlRequest.allHTTPHeaderFields = headers
var data = Data()
var value = "files"
// Add the userhash field and its value to the raw http reqyest data
data.append("rn--(boundary)rn".data(using: .utf8)!)
data.append("Content-Disposition: form-data; name="(paramName)"rnrn".data(using: .utf8)!)
data.append("(value)".data(using: .utf8)!)
// Add the image data to the raw http request data
data.append("rn--(boundary)rn".data(using: .utf8)!)
data.append("Content-Disposition: form-data; name="image"; filename="(fileName)"rn".data(using: .utf8)!)
data.append("Content-Type: image/jpegrnrn".data(using: .utf8)!)
data.append(UIImageJPEGRepresentation(image, 0.1)!)
data.append("rn--(boundary)--rn".data(using: .utf8)!)
urlRequest.httpBody = data
print("value of data is", data)
//NSString requestReply = [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding];
//print("requestReply: %@%@", requestReply);
let session = URLSession.shared
let dataTask = session.dataTask(with: urlRequest as URLRequest, completionHandler: { (data, response, error) -> Void in
if let _data = data
{
do {
var jsonResult: NSDictionary
try jsonResult = JSONSerialization.jsonObject(with: _data, options: JSONSerialization.ReadingOptions.mutableContainers) as! NSDictionary
print("AsSynchronous(jsonResult)")
}
catch {
// handle error
}
}
else
{
print("Error: no data for request (urlRequest)")
}
/* if (error != nil) {
print(error)
} else {
let httpResponse = response as? HTTPURLResponse
print("got any response")
print(NSString(data: data!, encoding: String.Encoding.utf8.rawValue))
print("may be")
print(httpResponse)
}*/
})
dataTask.resume()
}`
Ответ №1:
Вы помещаете Data
из файла изображения и Data
для тела формы вместе.
class HomeViewController: UIViewController {
override func viewDidLoad() {
super.viewDidLoad()
}
@IBAction func postTapped(_ sender: UIButton) {
postData()
}
func postData() {
let image = UIImage(imageLiteralResourceName: "myImage.jpg")
guard let imageData = UIImageJPEGRepresentation(image) else {
print("oops")
return
}
let url = URL(string: "http://www.example.net/example.php")
var request = URLRequest(url: url!)
request.httpMethod = "POST"
request.timeoutInterval = 30.0
let uuid = UUID().uuidString
let CRLF = "rn"
let filename = uuid ".jpg"
let formName = "file"
let type = "image/jpeg" // file type
let boundary = String(format: "----iOSURLSessionBoundary.xx", arc4random(), arc4random())
var body = Data()
// file data //
body.append(("--(boundary)" CRLF).data(using: .utf8)!)
body.append("Content-Disposition: form-data; name="formName"; filename="(fileName)"rn".data(using: .utf8)!)
body.append(("Content-Type: (type)" CRLF CRLF).data(using: .utf8)!)
body.append(imageData as Data)
body.append(CRLF.data(using: .utf8)!)
// footer //
body.append(("--(boundary)--" CRLF).data(using: .utf8)!)
request.setValue("multipart/form-data; boundary=(boundary)", forHTTPHeaderField: "Content-Type")
request.httpBody = body
let session = URLSession(configuration: .default)
session.dataTask(with: request) { (data, response, error) in
...
...
}
}
Комментарии:
1. Снова сталкиваюсь с той же проблемой. Использовал ваш код, единственное отличие в том, что я добавил let image = ImageView.image
2. ЯВЛЯЕТСЯ ЛИ UIImage(imageLiteralResourceName: «myImage.jpg «) то же, что imageview.image? Должен ли я сначала сохранять UIImage как ‘myIn=mage.jpg ‘ Если да, то как я могу это сделать?