【问题标题】:Set HTTP header for one request为一个请求设置 HTTP 标头
【发布时间】:2012-08-06 06:52:51
【问题描述】:

我的应用中有一个需要基本身份验证的特定请求,因此我需要为该请求设置 Authorization 标头。我读到了setting HTTP request headers,但据我所知,它将为该方法的所有请求设置该标头。我的代码中有这样的内容:

$http.defaults.headers.post.Authorization = "Basic QWxhZGRpbjpvcGVuIHNlc2FtZQ==";

但我不希望我的每个帖子请求都发送此标头。有没有办法只为我想要的一个请求发送标头?还是我必须在我提出请求后将其删除?

【问题讨论】:

    标签: javascript http-headers angularjs


    【解决方案1】:

    在您传递给$http 的配置对象中有一个标头参数,用于每次调用标头:

    $http({method: 'GET', url: 'www.google.com/someapi', headers: {
        'Authorization': 'Basic QWxhZGRpbjpvcGVuIHNlc2FtZQ=='}
    });
    

    或者用快捷方式:

    $http.get('www.google.com/someapi', {
        headers: {'Authorization': 'Basic QWxhZGRpbjpvcGVuIHNlc2FtZQ=='}
    });
    

    $http 服务文档中提供了有效参数的列表。

    【讨论】:

    • 我想我应该更仔细地看一下文档......我只是想使用快捷方式。这很好用。谢谢。
    • @dnc253 这也适用于快捷方式。代码为$http.get('www.google.com/someapi', {headers: {'Authorization': 'Basic QWxhZGRpbjpvcGVuIHNlc2FtZQ=='}});
    • 有没有办法扩展 $http (同时保持“可注入性”并且不必将其应用于默认标头集合)以自动为您添加此标头?总是必须为您进行的每个安全呼叫添加标头似乎有点多余。
    • 对我不起作用。我以这种方式添加的任何标头都不会添加到实际请求中。
    • 每当我尝试设置标头时,我的请求都会作为OPTION 请求发出,因此我的端点返回一个404 NOT FOUND,这是有道理的:它只知道GET /someResource 而不是OPTIONS /someResource
    【解决方案2】:

    试试这个,也许它有效;)

    .factory('authInterceptor', function($location, $q, $window) {
    
    
    return {
        request: function(config) {
          config.headers = config.headers || {};
    
          config.headers.Authorization = 'xxxx-xxxx';
    
          return config;
        }
      };
    })
    
    .config(function($httpProvider) {
      $httpProvider.interceptors.push('authInterceptor');
    })
    

    并确保您的后端也能正常工作, 尝试这个。我正在使用 RESTful CodeIgniter。

    class App extends REST_Controller {
        var $authorization = null;
    
        public function __construct()
        {
            parent::__construct();
            header('Access-Control-Allow-Origin: *');
            header("Access-Control-Allow-Headers: X-API-KEY, Origin, X-Requested-With, Content-Type, Accept, Access-Control-Request-Method, Authorization");
            header("Access-Control-Allow-Methods: GET, POST, OPTIONS, PUT, DELETE");
            if ( "OPTIONS" === $_SERVER['REQUEST_METHOD'] ) {
                die();
            }
    
            if(!$this->input->get_request_header('Authorization')){
                $this->response(null, 400);    
            }
    
            $this->authorization = $this->input->get_request_header('Authorization');
        }
    
    }
    

    【讨论】:

      猜你喜欢
      • 2014-08-23
      • 1970-01-01
      • 1970-01-01
      • 2013-04-12
      • 2020-05-05
      • 2014-03-24
      • 2016-03-31
      • 2014-02-13
      • 2011-06-24
      相关资源
      最近更新 更多