How to upload a file in Dart?

前端 未结 1 373
萌比男神i
萌比男神i 2020-12-03 03:48

I\'m trying to find any examples of uploading a file with a Dart script.

I understand the part about reading it on the client side after being selected in a file inp

1条回答
  •  轻奢々
    轻奢々 (楼主)
    2020-12-03 04:37

    Until a multipart encoding parser is available, you can use File API on client to read and upload file content as dataUrl. This API has quite good support in browsers ( see http://caniuse.com/filereader ).

    On client side :

    import 'dart:html';
    
    main() {
      InputElement uploadInput = query('#upload');
      uploadInput.onChange.listen((e) {
        // read file content as dataURL
        final files = uploadInput.files;
        if (files.length == 1) {
          final file = files[0];
          final reader = new FileReader();
          reader.onLoad.listen((e) {
            sendDatas(reader.result);
          });
          reader.readAsDataUrl(file);
        }
      });
    }
    
    /// send data to server
    sendDatas(dynamic data) {
      final req = new HttpRequest();
      req.onReadyStateChange.listen((Event e) {
        if (req.readyState == HttpRequest.DONE &&
            (req.status == 200 || req.status == 0)) {
          window.alert("upload complete");
        }
      });
      req.open("POST", "http://127.0.0.1:8080/upload");
      req.send(data);
    }
    

    And on server side :

    import 'dart:io';
    
    main() {
      final server = new HttpServer();
      server.listen('127.0.0.1', 8080);
      server.addRequestHandler((request) => request.path == '/upload' 
          && request.method.toLowerCase() == 'post'
          , (HttpRequest request, HttpResponse response) {
        _readBody(request, (body) {
    
          // handle your dataURL
          // example with image : ... 
    
          // return result
          response.statusCode = HttpStatus.CREATED;
          response.contentLength = 0;
          response.outputStream.close();
        });
      });
    }
    
    /// Read body of [request] and call [handleBody] when complete.
    _readBody(HttpRequest request, void handleBody(String body)) {
      String bodyString = ""; // request body byte data
      final completer = new Completer();
      final sis = new StringInputStream(request.inputStream, Encoding.UTF_8);
      sis.onData = (){
        bodyString = bodyString.concat(sis.read());
      };
      sis.onClosed = () {
        completer.complete("");
      };
      sis.onError = (Exception e) {
        print('exeption occured : ${e.toString()}');
      };
      // process the request and send a response
      completer.future.then((_){
        handleBody(bodyString);
      });
    }
    

    References :

    • Reading files in JavaScript using the File APIs

    0 讨论(0)
提交回复
热议问题