Установить HTTP-заголовок для одного запроса

У меня есть один конкретный запрос в моем приложении, для которого требуется обычная проверка подлинности, поэтому мне нужно установить заголовок авторизации для этого запроса. Я читал о настройке заголовков HTTP-запросов, но из того, что я могу сказать, он установит этот заголовок для всех запросов этого метода. В моем коде есть что-то подобное:

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

Но я не хочу, чтобы каждый мой почтовый запрос отправлял этот заголовок. Есть ли способ отправить заголовок только для одного запроса, который я хочу? Или мне нужно удалить его после моего запроса?

Ответ 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.

Ответ 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');
    }

}