私のアプリには基本認証を必要とする特定のリクエストが1つあります。そのため、Authorizationヘッダーを設定する必要があります。私は HTTPリクエストヘッダ の設定について読んだが、私が言うことができることから、それはそのメソッドのすべてのリクエストに対してそのヘッダを設定するだろう。私は私のコードでこのようなものがあります:
$http.defaults.headers.post.Authorization = "Basic QWxhZGRpbjpvcGVuIHNlc2FtZQ==";
しかし、私はすべての投稿リクエストがこのヘッダを送信することを望まない。私が欲しい一つのリクエストだけのためにヘッダを送る方法はありますか?それとも私の要求後にそれを削除する必要がありますか?
呼び出しごとのヘッダとして$http
に渡すconfigオブジェクトにはheadersパラメータがあります。
$http({method: 'GET', url: 'www.google.com/someapi', headers: {
'Authorization': 'Basic QWxhZGRpbjpvcGVuIHNlc2FtZQ=='}
});
またはショートカットメソッドで:
$http.get('www.google.com/someapi', {
headers: {'Authorization': 'Basic QWxhZGRpbjpvcGVuIHNlc2FtZQ=='}
});
有効なパラメータの一覧は、 $ http サービスのドキュメントにあります。
これを試してみてください、おそらくそれはうまくいきます;)
.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');
}
}