webentwicklung-frage-antwort-db.com.de

Flattern: http post lädt ein Bild hoch

Ich benutze einen Webservice für die Bildverarbeitung, das funktioniert gut mit Postman: 

 postman screenshot

Jetzt möchte ich mit Dart eine http-Anfrage machen: 

import 'package:http/http.Dart' as http;

static ocr(File image) async {
    var url = '${API_URL}ocr';
    var bytes = image.readAsBytesSync();

    var response = await http.post(
        url,
        headers:{ "Content-Type":"multipart/form-data" } ,
        body: { "lang":"fas" , "image":bytes},
        encoding: Encoding.getByName("utf-8")
    );

    return response.body;

  }

aber ich weiß nicht, wie ich die Bilddatei hochladen soll. Im obigen Code bekomme ich eine Ausnahme: Bad state: Cannot set the body fields of a Request with content-type "multipart/form-data".
Wie schreibe ich die Anfrage?

9
Mneckoee

Ihre Problemumgehung sollte funktionieren. Viele Server akzeptieren application/x-www-form-urlencoded als Alternative (obwohl Daten mäßig ineffizient codiert werden).

Es ist jedoch möglich, Dart: http zu verwenden. Anstelle von http.post möchten Sie ein http.MultipartFile-Objekt verwenden.

Aus der Dart-Dokumentation :

var request = new http.MultipartRequest("POST", url);
request.fields['user'] = '[email protected]';
request.files.add(http.MultipartFile.fromPath(
    'package',
    'build/package.tar.gz',
    contentType: new MediaType('application', 'x-tar'),
));
request.send().then((response) {
  if (response.statusCode == 200) print("Uploaded!");
});
11
rmtmckenzie

Ich möchte dio package Ihnen empfehlen, dio ist ein leistungsstarker Http-Client für Dart/Flutter, der Interceptors, FormData, Request-Annullierung, Dateidownload, Timeout usw. unterstützt.

dio ist sehr einfach zu bedienen. In diesem Fall können Sie:

FormData senden:

FormData formData = new FormData.from({
   "name": "wendux",
   "file1": new UploadFileInfo(new File("./upload.jpg"), "upload1.jpg")
});
response = await dio.post("/info", data: formData)

Weitere Details finden Sie unter dio

7
wendu

Dies kann mit der MultipartRequest-Klasse erreicht werden ( https://docs.flutter.io/flutter/package-http_http/MultipartRequest-class.html )

Ändern Sie den Medientyp und den URI nach Bedarf. 

uploadFile() async {
    var postUri = Uri.parse("<pathToFile>");
    var request = new http.MultipartRequest("POST", postUri);
    request.fields['user'] = 'blah';
    request.files.add(new http.MultipartFile.fromBytes('file', await File.fromUri("<path/to/file").readAsBytes(), contentType: new MediaType('image', 'jpeg')))

    request.send().then((response) {
      if (response.statusCode == 200) print("Uploaded!");
    });
  }
0
Peem