Angularjs ngResource需要将文件作为其中一个字段

Sla*_*mac 5 rest post file-upload angularjs ngresource

我有以下字段的资源:

description, picture
Run Code Online (Sandbox Code Playgroud)

是否可以将该资源作为multipart/form发送到URL,如果是,如何?

我试过放:

app.factory('resource_name', ['$resource', function($resource) {
return $resource('<url> ',
    {
            <params_for_url>
    },
        save: {
            method: "POST",
            headers: {
                "Content-Type": "multipart/form-data;"
            }
        },
Run Code Online (Sandbox Code Playgroud)

但这不会作为表单数据到达服务器.它就像JSON一样只设置了标题:

{
description: "gtrdgf",
picture: {
    lastModifiedDate:2013-11-26T20:42:13.000Z,
    name: "suggested_pokes.png"
    size: 32995
    type: "image/png"
    webkitRelativePath: ""
}
Run Code Online (Sandbox Code Playgroud)

有没有人之前满足这个要求?如果这是可能的话......

谢谢!

Sla*_*mac 11

我找到了这个解决方案.您必须使用FormData提交它.你可以用它作为拦截器.我这样使用它(这是我的ngResource的保存方法)

            save: {
                method: 'POST',
                transformRequest: formDataObject,
                headers: {'Content-Type':undefined, enctype:'multipart/form-data'}
            },
Run Code Online (Sandbox Code Playgroud)

这是变压器:

        function formDataObject (data) {
            var fd = new FormData();
            angular.forEach(data, function(value, key) {
                fd.append(key, value);
            });
            return fd;
        }
Run Code Online (Sandbox Code Playgroud)