如何使用grails 2.5.3的ng-file-upload

时间:2017-02-06 20:27:23

标签: angularjs grails ng-file-upload grails-2.5

我正在尝试使用ng-file-upload将多个文件同时上传到我的grails控制器操作。但是,我无法弄清楚如何获取正在上传到操作的文件。

这是我的JS代码:

app.controller('MyCtrl', ['$scope', 'Upload', '$timeout', function ($scope, Upload, $timeout) {
    $scope.uploadFiles = function (files) {
        $scope.files = files;
        if (files && files.length) {
            Upload.upload({
                url: 'http://localhost:8080/classifydemo/request/create',
                data: {
                    files: files
                }
            }).then(function (response) {
                $timeout(function () {
                    $scope.result = response.data;
                });
            }, function (response) {
                if (response.status > 0) {
                    $scope.errorMsg = response.status + ': ' + response.data;
                }
            }, function (evt) {
                $scope.progress = 
                    Math.min(100, parseInt(100.0 * evt.loaded / evt.total));
            });
        }
    };
}]);

我的Grails行动如下:

class RequestController {

    def create() {
        request.headerNames.each{
           println it
        }
        println params
        println request.getFile("file")
        render "test"
    }

}

以上代码在request.getFile上失败。

问题

如何保存正在上传到控制器的文件,以便我可以循环处理它们。

1 个答案:

答案 0 :(得分:0)

由于您可以使用多个文件:

request.fileNames.each {
  MultipartFile file = request.getFile(it)
  // do whatever you want with the file
}