私は angular.js の初心者で、リクエストにいくつかのヘッダーを追加しようとしています:
var config = {headers: {
'Authorization': 'Basic d2VudHdvcnRobWFuOkNoYW5nZV9tZQ==',
'Accept': 'application/json;odata=verbose'
}
};
$http.get('https://www.example.com/ApplicationData.svc/Malls(1)/Retailers', config).success(successCallback).error(errorCallback);
私はすべてのドキュメントを見てきましたが、これは正しいはずだと私には思えます。
の URL にローカル ファイルを使用すると$http.get
、Chrome の [ネットワーク] タブに次の HTTP 要求が表示されます。
GET /app/data/offers.json HTTP/1.1
Host: www.example.com
Connection: keep-alive
Cache-Control: max-age=0
If-None-Match: "0f0abc9026855b5938797878a03e6889"
Authorization: Basic Y2hhZHN0b25lbWFuOkNoYW5nZV9tZQ==
Accept: application/json;odata=verbose
X-Requested-With: XMLHttpRequest
If-Modified-Since: Sun, 24 Mar 2013 15:58:55 GMT
User-Agent: Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.22 (KHTML, like Gecko) Chrome/25.0.1364.172 Safari/537.22
X-Testing: Testing
Referer: http://www.example.com/app/index.html
Accept-Encoding: gzip,deflate,sdch
Accept-Language: en-US,en;q=0.8
Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.3
ご覧のとおり、両方のヘッダーが正しく追加されています。しかし、URL を$http.get
上記のように変更すると (example.com ではなく実際のアドレスを使用する場合を除く)、次のようになります。
OPTIONS /ApplicationData.svc/Malls(1) HTTP/1.1
Host: www.datahost.net
Connection: keep-alive
Access-Control-Request-Method: GET
Origin: http://mpon.site44.com
User-Agent: Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.22 (KHTML, like Gecko) Chrome/25.0.1364.172 Safari/537.22
Access-Control-Request-Headers: accept, origin, x-requested-with, authorization, x-testing
Accept: */*
Referer: http://mpon.site44.com/app/index.html
Accept-Encoding: gzip,deflate,sdch
Accept-Language: en-US,en;q=0.8
Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.3
これら 2 つのコードの唯一の違いは、1 つ目は URL がローカル ファイルであり、2 つ目は URL がリモート サーバーであることです。2 番目の Request ヘッダーを見ると、Authentication ヘッダーがAccept
なく、指定されたものではなくデフォルトを使用しているように見えます。また、最初の行はOPTIONS
代わりに言うようになりましたGET
(しかしAccess-Control-Request-Method
is GET
)。
上記のコードの何が問題なのか、またはローカル ファイルをデータ ソースとして使用しない場合に追加のヘッダーを追加する方法を教えてください。