2014-09-03 57 views
0

服务器的nod​​e.js我简单多FORMDATA后输入类型的文件,从角服务呼叫

<form action="/upload" enctype="multipart/form-data" method="post"> 
     <span class="btn btn-file"> 
     <input type="file" name="file" ng-model="file"/> 
     <span class="btn btn-primary" ng-click="upload()">Upload</span> 
     </span> 
</form> 

我想这样做,张贴所有文件写在Node.js的服务器相关信息

server.js这是写入节点的文件上传处理程序。强大的期望文件的所有参数。

upload: function uploadfn (req, res) { 

    var form = new formidable.IncomingForm(); 
    form.parse(req, function(err, fields, files) { 
     // `file` is the name of the <input> field of type `file` 
     var old_path = files.file.path, 
     file_size = files.file.size, 
     file_ext = files.file.name.split('.').pop(), 
     index = old_path.lastIndexOf('/') + 1, 
     file_name = old_path.substr(index), 
     new_path = path.join(process.env.PWD, '/uploads/', file_name + '.' + file_ext); 
     fs.readFile(old_path, function(err, data) { 
      fs.writeFile(new_path, data, function(err) { 
       fs.unlink(old_path, function(err) { 
        if (err) { 
         res.status(500); 
         res.json({'success': false}); 
        } else { 
         res.status(200); 
         res.json({'success': true}); 
        } 
       }); 
      }); 
     }); 
    }); 
} 

我坚持的东西在,我根本服务呼叫准备在角如下:

service.factory('FileUpload', function ($resource) { 
    return $resource('/upload', {}, { 
     post: {method: 'POST'} 
    }); 
}); 

此调用打后端从角控制器如下

$scope.upload = function(){ 
    console.log($scope.file); 
    FileUpload.post(function(){ 
    }); 
} 

我不知道如何发布文件提交,以便节点可以捕获它。另外$ scope.file是未定义的。

请帮我解决这个问题。

回答