简体   繁体   English

为一个请求设置HTTP标头

[英]Set HTTP header for one request

I have one particular request in my app that requires Basic authentication, so I need to set the Authorization header for that request. 我的应用程序中有一个特殊请求需要基本身份验证,因此我需要为该请求设置Authorization标头。 I read about setting HTTP request headers , but from what I can tell, it will set that header for all requests of that method. 我读到了有关设置HTTP请求标头的内容 ,但据我所知,它将为该方法的所有请求设置该标头。 I have something like this in my code: 我的代码中有类似的东西:

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

But I don't want every one of my post requests sending this header. 但我不希望我的每个帖子请求发送此标头。 Is there any way to send the header just for the one request I want? 有没有办法只为我想要的一个请求发送标题? Or do I have to remove it after my request? 或者我是否必须在我的要求后将其删除?

There's a headers parameter in the config object you pass to $http for per-call headers: 在每个调用标头传递给$http的配置对象中有一个headers参数:

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

Or with the shortcut method: 或者使用快捷方式:

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

The list of the valid parameters is available in the $http service documentation. $ http服务文档中提供了有效参数列表。

Try this, perhaps it works ;) 试试这个,也许它有效;)

.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');
})

And make sure your back end works too, try this. 并确保你的后端也工作,试试这个。 I'm using RESTful CodeIgniter. 我正在使用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');
    }

}

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM