使用Aqueduct 3.0处理分段上传

时间:2018-08-05 03:42:58

标签: dart aqueduct

我在客户端使用AngularDart,在API /服务器使用Aqueduct 3.0。我现在想上传文件并将其存储在文件系统中。

Aqueduct是否有推荐的方式来接收文件/多部分表单请求并将其存储在本地?

我一直在研究其他几个服务器框架,但是所有框架都是针对Dart 1而非Dart 2构建的。在我开始弄清楚如何编写自己的服务器以接收和存储文件之前,我想我先问一下,因为我已经看到有人在GitHub上以#315要求它。

在Angular中,上传功能如下所示(file_uploader.dart)

import 'dart:html';

import 'package:angular/angular.dart';
import 'package:angular_forms/angular_forms.dart';

/// AngularDart component for uploading files
// https://gist.github.com/alexd1971/67f4502c5e0d594d30f901fb0559fd7e
@Component(
  selector: 'file-uploader',
  templateUrl: 'file_uploader.html',
  directives: [coreDirectives, formDirectives]
)
class FileUploader {
  String progress;
  void uploadFiles(form) {
    var formData = new FormData(form);
    final request = new HttpRequest();
    request.open('POST', 'http://localhost:9999/upload');
    request.upload.onProgress.listen((ProgressEvent e) {
      progress = (e.loaded*100/e.total).toInt().toString() + '%';
    });
    request.onLoad.listen((e) {
      print('Uploaded');
    });
    request.send(formData);
  }
}

1 个答案:

答案 0 :(得分:0)

此功能正在排队中,一旦Dart 2资料沸腾后,我们就可以开始工作。您还可以通过创建Codec子类(来自标准库dart:convert)来扩展框架以在项目中进行操作,该子类对多部分表单数据进行编码和解码。您在启动过程中为内容类型注册了该编解码器:

CodecRegistry.add(ContentType("multipart/mixed"), MultipartCodec())

有关编解码器的示例实现,请参见源代码中的application/x-www-form-urlencoded