Cookie未保存在浏览器中

问题描述 投票:0回答:1

我正在尝试使用Python Flask后端在我的浏览器中设置一个cookie但是,当我们调用set cookie函数时,我无法观察到浏览器保存的cookie。以下是我目前对如何工作的理解:

  • Cookie只是可能具有过期的键值对,这使得它们是持久的,否则它们会在浏览器关闭时到期
  • 要设置cookie,所有必要的是在响应中使用set-cookie标头。我调用flask响应对象的set_cookie方法来执行此操作。
  • 浏览器应自动保存cookie并遵循过期规则(可以在浏览器收到的响应中观察到set_cookie标头)

在Angular HttpClient中发出请求

let headers = new Headers();
headers.append('Content-Type', 'application/json');
let options = new RequestOptions({ headers: headers, withCredentials: true });
const request_data = {'username': this.username, 'password': this.password};
this.http.post('http://localhost:8080/token', request_data, options)

在Python Flask中设置cookie

g.response = make_response()
time = datetime.datetime.now() + datetime.timedelta(days=30)
g.response.set_cookie("auth_token", auth.token, expires=time)
return g.response

浏览器中的纯文本响应

HTTP/1.1 200 OK
set-cookie: auth_token=7253f2fa43d7584741dcf8972dea8f; Expires=Fri, 05-Jan-2018 01:33:30 GMT; Path=/
vary: Origin
access-control-allow-credentials: true
access-control-allow-origin: http://127.0.0.1:4200
content-type: application/json
Expires: Fri, 01 Jan 1990 00:00:00 GMT
Cache-Control: no-cache
Content-Length: 58
Server: Development/2.0
Date: Wed, 06 Dec 2017 01:33:30 GMT

浏览器的cookie部分screenshot of no cookies being saved

其他想法和帖子探讨:

题:

如何让浏览器保存cookie以便在当前会话中使用?

python cookies browser
1个回答
1
投票

cookie的域设置为环回地址(127.0.0.1)。在angular中,我使用'localhost'而不是环回地址来调用set-cookie端点,这阻止了cookie被保存在浏览器中。只要使用环回地址匹配cookie域,端点基本URL和浏览器地址,一切都按预期工作。

有趣的注意事项:目前我不确定为什么,但匹配的地址似乎不够。我还尝试将cookie域,端点基本URL和浏览器地址都设置为“localhost”,但这仍然没有设置cookie。它只在所有值都是环回地址时才起作用。

© www.soinside.com 2019 - 2024. All rights reserved.