別のサービスAPIへの呼び出しをAJAXしているのですが、このAPIは、残りのAPI呼び出しを実行できるようにブラウザーに設定されるCookieを返すことになっています。
ただし、応答ヘッダーには「Set-Cookie」ヘッダーが含まれていますが、実際にCookieが設定されることはありません。私はGoogleChromeを使用しています。
応答ヘッダーは次のとおりです。
Access-Control-Allow-Origin:*
Cache-Control:no-cache
Connection:keep-alive
Content-Encoding:gzip
Content-Length:37
Content-Type:application/json
Date:Thu, 25 Jun 2015 18:27:37 GMT
Expires:Thu, 25 Jun 2015 18:27:36 GMT
Server:nginx/1.4.6 (Ubuntu)
Set-Cookie:sessionid=67cb9796aa794a4975b28876ea6dd3d5; expires=Thu, 09-Jul-2015 18:27:37 GMT; httponly; Max-Age=1209600; Path=/
Vary:Cookie
そしてここにAJAX呼び出し:
$.ajax({
type: "POST",
crossDomain: true,
contentType: 'text/plain',
data: data,
url: urlhere
success: function(result, status, xhr){
console.log('hi');
console.log(xhr.getAllResponseHeaders());
},
error: function(xhr){
console.log(xhr.status);
console.log(xhr.statusText);
}
});
Chromeリソースページには、Cookieが設定されていないことも示されています。すべてのヘルプをいただければ幸いです。
XHR呼び出しにwithCredentials
を追加する必要があります。この回答は、jQueryを使用してそれを行う方法を示しています。 https://stackoverflow.com/a/7190487 その追加のフラグがないと、ブラウザはset-cookieヘッダーを受け入れません。