search

Home  >  Q&A  >  body text

angular.js - How to set the header of all requests in angularjs ngResource?

I want to submit a header in every request, something like a: bbb.

    // 无论是获取列表
    $scope.books = myRes.query();
    // 还是单独的一个项目
    $scope.oneBook = myRes.get({id:2});

Can add a header to all RESTful requests, the content of the header is

    ca-g-oo: data-dnwaec2ioagwqevnm

I tried various methods but couldn’t achieve it

$resource(url, [paramDefaults], [actions]);

url is the address to set the request
paramDefaults is the preset data to be submitted
action is a custom function method

It feels like it can be set through action, but it doesn’t work

    // 如果把action设置成这样
    $resource(
        'ca/book/:id',
        {},
        {
            query: {
                header: {
                    "ca-g-oo": "data-dnwaec2ioagwqevnm"
                }
            },
            get: {
                header: {
                    "ca-g-oo": "data-dnwaec2ioagwqevnm"
                }
            }
        }
    );

I reported an error

    Error: [$resource:badcfg] http://errors.angularjs.org/1.2.29/$resource/badcfg?p0=object&p1=array

How do I set up $resource so that all requests carry my customized header?

phpcn_u1582phpcn_u15822794 days ago840

reply all(3)I'll reply

  • 習慣沉默

    習慣沉默2017-05-15 17:02:27

    interreputor can satisfy you

    reply
    0
  • 滿天的星座

    滿天的星座2017-05-15 17:02:27

    The problem is also solved. . When setting $resource, set the isArray attribute

    isArray property


    The complete code is as follows

    'amd';
    /**
     * 
     * RESTful创建服务
     * by chenxuan 20160325
     *
     * 创建一个$resource对象
     * query : 获取列表
     * get : 获取单个数据
     * updata : 更新数据
     * save : 新建数据保存
     *
     * 关于缓存
     * 默认缓存query和get请求,当有updata和save请求产生的时候清空所有缓存
     *
     * ====v1.1====20160328
     * functionSetting参数的对象不会直接覆盖没有在对象中存在的默认属性
     * 
     */
    define(
        [
            'app'
        ],
        function (app){
            app.factory('RESTful', function ($resource,$cacheFactory){
                return function (url, defaultParam, functionSetting){
                    var RESTfulCacheID = "" + Math.random();
                    var RESTfulCache = $cacheFactory(RESTfulCacheID, {capacity: 10});
                    var defaultFunction = {
                        query: {
                            method: 'GET',
                            isArray: true,
                            headers: {
                                'X-CSRF-TOKEN': app.CSRF_TOKEN
                            },
                            cache: RESTfulCache
                        },
                        get: {
                            method:'GET',
                            isArray: false,
                            headers: {
                                'X-CSRF-TOKEN': app.CSRF_TOKEN
                            },
                            cache: RESTfulCache
                        },
                        update: {
                            method:'PUT',
                            isArray: false,
                            headers: {
                                'X-CSRF-TOKEN': app.CSRF_TOKEN
                            },
                            transformResponse: function (data, headers){
                                RESTfulCache.removeAll();
                            }
                        },
                        save : {
                            method:'POST',
                            isArray: false,
                            headers: {
                                'X-CSRF-TOKEN': app.CSRF_TOKEN
                            },
                            transformResponse: function (data, headers){
                                RESTfulCache.removeAll();
                            }
                        }
                    };
    
                    if(functionSetting){
                        for(var i in functionSetting){
                            if(typeof defaultFunction[i] == typeof {}){
                                for(var j in functionSetting[i]){
                                    defaultFunction[i][j] = functionSetting[i][j];
                                }
                            }else{
                                defaultFunction[i] = functionSetting[i];
                            }
                        }
                    }
                    var returnRes = $resource(url, defaultParam, defaultFunction);
                    returnRes.getCache = function (){
                        return RESTfulCache;
                    }
                    return returnRes;
                }
            });
        }
    )

    reply
    0
  • 大家讲道理

    大家讲道理2017-05-15 17:02:27

    Use route interceptor to define global header

       $httpProvider.interceptors.push(['$rootScope', '$q', function ($rootScope, $q) {
    
          return {
            request: function (config) {
    
              // Header - Token
              config.headers = config.headers || {};
              if (config.headers) {
                config.headers['ca-g-oo'] = 'data-dnwaec2ioagwqevnm';
              };
              
              return config;
            },
    
            response: function (response) {
    
              if (response.status == 200) {
                // console.log('do something...');
              }
              
              return response || $q.when(response);
            },
    
            responseError: function (response) {
       
              return $q.reject(response);
            }
          }
        }])

    reply
    0
  • Cancelreply