我正在尝试使用Python Flask后端在我的浏览器中设置一个cookie但是,当我们调用set cookie函数时,我无法观察浏览器保存的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以便在当前会话中使用?
答案 0 :(得分:1)
cookie的域设置为环回地址(127.0.0.1)。在angular中,我使用'localhost'而不是环回地址来调用set-cookie端点,这阻止了cookie被保存在浏览器中。只要使用环回地址匹配cookie域,端点基本URL和浏览器地址,一切都按预期工作。
有趣的注意事项:目前我不确定为什么,但匹配的地址似乎不够。我还尝试将cookie域,端点基本URL和浏览器地址都设置为“localhost”,但这仍然没有设置cookie。它只在所有值都是环回地址时才起作用。