zoukankan      html  css  js  c++  java
  • 在AngularJs中怎么设置请求头信息(headers)及不同方法的比较

    AngularJS中有三种方式可以设置请求头信息:

    1、在httphttp()方法时,在config对象中设置请求头信息:事例如下:

        $http.post('/somePath' , someData , {
            headers : {'Authorization' : authToken}
        }).success(function(data, status, headers, config) {
            //...
        }).error(function(data, status, headers, config ) {
            //...
        });
    

    这种方法的好处就是针对不同路径的请求,可以个性化配置请求头部,缺点就是,不同路径请求都需要单独配置。

    2、第二种设置请求头信息的方式就是在$httpProvider.defaults.headers属性上直接配置。事例如下:

    ngular.module('app', [])
    .config(function($httpProvider) {
        $httpProvider.defaults.headers.common = { 'My-Header' : 'value' }
    })
    

    $httpProvider.defaults.headers有不同的属性,如common、get、post、put等。因此可以在不同的http请求上面添加不同的头信息,common是指所有的请求方式。

    这种方式添加请求头信息的优势就是可以给不同请求方式添加相同的请求头信息,缺点就是不能够为某些请求path添加个性化头信息。

    3、第三种设置请求头信息的地方是$httpProvider.interceptors。也就是为请求或相应注册一个拦截器。使用这这方式我们首先需要定义一个服务。

    myModule.factory('authInterceptor', function($rootScope,  $cookies){
        return {
            request: function(config){
                config.headers = config.headers || {};
                if($cookies.get('token')){
                    config.headers.authorization = 'Bearer ' + $cookies.get('token');
                }
                return config;
            },
            responseError: function(response){
                // ...
            }
        };
    })
    

    然后把上面定义的服务注册到$httpProvider.interceptors中。

    .config(function($httpProvider){
        $httpProvider.interceptors.push('authInterceptor');
    })
    

    这样,对于每次请求,不论是get还是post、put。我们都会在请求头信息中加入authorization属性。这种方式在处理验权、授权方面很有用的。但是确定就是不能够为特定的请求方式添加请求头信息。

    上面总共有三种方式设置头信息,选择那种方式可以根据自己的需求。

  • 相关阅读:
    Circular dependency issuse on cocoapods version(0.36.0) 全然解决方式(非降版本号)
    Android Studio经常使用配置及使用技巧(二)
    poj 2195 Going Home(最小费最大流)
    OpenFace库(Tadas Baltrusaitis)中基于Haar Cascade Classifiers进行人脸检測的測试代码
    Divisibility by Eight
    hdu 5055(坑)
    微服务(Microservices)
    mysql 运行计划explain具体解释
    URAL 题目1297. Palindrome(后缀数组+RMQ求最长回文子串)
    Windows下将nginx安装为服务运行
  • 原文地址:https://www.cnblogs.com/wbxjiayou/p/6108552.html
Copyright © 2011-2022 走看看