web-dev-qa-db-ja.com

Set-CookieヘッダーがChrome

別のサービス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が設定されていないことも示されています。すべてのヘルプをいただければ幸いです。

13
MattA

XHR呼び出しにwithCredentialsを追加する必要があります。この回答は、jQueryを使用してそれを行う方法を示しています。 https://stackoverflow.com/a/7190487 その追加のフラグがないと、ブラウザはset-cookieヘッダーを受け入れません。

13
SuperSaiyen