5

我有具有以下字段的资源:

description, picture

是否可以将该资源作为多部分/表单发送到 URL,如果可以,如何发送?

我试过把:

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

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

{
description: "gtrdgf",
picture: {
    lastModifiedDate:2013-11-26T20:42:13.000Z,
    name: "suggested_pokes.png"
    size: 32995
    type: "image/png"
    webkitRelativePath: ""
}

以前有人满足过这个要求吗?如果这是可能的...

谢谢!

4

1 回答 1

11

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

            save: {
                method: 'POST',
                transformRequest: formDataObject,
                headers: {'Content-Type':undefined, enctype:'multipart/form-data'}
            },

这是变压器:

        function formDataObject (data) {
            var fd = new FormData();
            angular.forEach(data, function(value, key) {
                fd.append(key, value);
            });
            return fd;
        }
于 2014-10-01T13:05:39.700 回答