如何使$resource接受字符串数组(AngularJS)



我想向REST服务发出请求,其中查询参数包含字符串数组:

productRestService.getProductsInfo(productIdsArray,"id,name,rating").$promise.
               then(function(productData) { // success: Produktdaten auslesen                
                    updateProductList(productData);
                }, function (error) {
                    console.log("Status: " + error.status);       
                });

资源服务如下:

productRestService.getProductsInfo = function(productIds, properties) {
        console.log('productRestService.getProductsInfo(): productIds' + productIds);
        var productInfoResourceData;
        var ProductInfoResource = $resource('/rest/products/productsInfo/:productIds/:properties',
            {
                productIds:'@productIds',
                properties:'@properties'
            }
        );
        productInfoResourceData = ProductInfoResource.query(
            {
                productIds: productIds,
                properties: properties
            }
        );
        return productInfoResourceData;
    }

调用服务会导致404错误,因为$resource对象的默认行为是,当使用"query"时,它需要一个对象数组。

如何实现$resourcee服务将接受字符串数组?我尝试使用"transformRequest"(请参阅下面的片段),但也不起作用。

  {
                query: {
                  method: 'GET',
                  isArray: true,
                  transformResponse: function (data, headers) {
                    var tranformed = [];
                    [].forEach.call(eval(data), function (d) {
                        tranformed.push({ name: d });
                    });
                    return tranformed;
                    }
                }
            }

REST服务产品service.getProductsInfo函数中的console.log显示服务接收到的正确数据:

["212999cc-063b-4ae8-99b5-61a0af39040d","17e42a28-b945-4d5f-bab1-719b3a897fd0","9307df3e-6e7a-4bed-9fec-a9d925ea7dc0"]

URL与其他REST-URLS是正确的,应该是这样的(并相应地连接到域):

'/rest/products/productsInfo/:productIds/:properties'

编辑:productService中的其他函数按顺序响应,它们不使用数组,而是使用JSON对象,并且不会显示意外行为。

(这最初是一个注释,但它需要格式干净的代码示例。)

我怀疑您的:productIds模板参数正在作为"[object Object]"填充到模板中。我只看到了你的模板URL,而不是实际构建的URL,所以我不能确定。

如果您的服务器需要一个:productsIds模板参数为JSON的URL,例如---

rest/products/productsInfo/["id1","id2","id3"]/{"prop1":true,"prop2":false}

---然后尝试将getProductsInfo定义编辑为这样的内容:

productRestService.getProductsInfo = function (productIds, properties) {
    var ProductsInfo = $resource('/rest/products/productsInfo/:productIds/:properties', {
        productIds: function () {
            return angular.toJson(productIds);
        },
        properties: function () {
            return angular.toJson(properties);
        }
    });
    return ProductsInfo.query();
}

(公平地警告,我没有测试这个代码。这只是对您的示例的快速编辑。)

通过这种方式,您可以确保参数值转换为服务器期望的JSON(如果服务器在URL中期望JSON,也就是说)。

最新更新