Flask跨域Cookie设置:确保前端正确接收的实践指南

Flask跨域Cookie设置:确保前端正确接收的实践指南

本教程详细探讨了在Flask后端与VueJS前端进行跨域通信时,如何正确设置并确保浏览器接收Cookie。重点分析了Flask中make_response和set_cookie的正确使用方式,并指出常见的返回错误,同时强调了CORS配置和前端withCredentials的重要性,旨在帮助开发者避免Cookie设置失败的问题。

1. Flask中Cookie设置机制概述

在web开发中,cookie是服务器向客户端浏览器发送的一小段数据,浏览器会将其保存并在后续请求中发送回服务器,常用于会话管理、用户身份认证等。在flask应用中,设置cookie通常涉及以下几个核心步骤:

创建响应对象:Flask的视图函数通常返回字符串、字典(会自动被jsonify处理成JSON响应)或Response对象。当需要对响应进行更细粒度的控制(如设置Cookie、HTTP头等)时,需要显式地创建一个Response对象。设置Cookie:在创建的Response对象上调用set_cookie()方法来添加Cookie。返回响应对象:将设置好Cookie的Response对象返回给客户端。

2. 问题分析:为何Cookie未能正确设置

许多开发者在Flask中尝试设置Cookie时,会遇到Cookie无法在浏览器中显示的问题。这通常发生在以下场景:前端(如VueJS配合Axios)发起请求,后端(Flask)处理认证逻辑并尝试设置Cookie,但最终浏览器并未存储Cookie。

考虑以下一个典型的Flask后端代码片段,其中包含一个常见的错误:

# main.pyfrom flask import Flask, make_response, jsonifyfrom flask_cors import CORS, cross_origin# 假设 user 模块和 loginAccount 函数已定义app = Flask(__name__)CORS(app, support_credentials=True) # 启用CORS并支持凭据@app.route('/api/account/login', methods=['POST'])@cross_origin(supports_credentials=True)def login_account():    # loginAccount() 应该返回一个 Flask Response 对象    return loginAccount()if __name__ == '__main__':    app.run(debug=True)
# user.py (包含错误示例)from flask import make_response, jsonify # 假设 db 和 jwt 等已导入和配置def loginAccount():    # 假设 email, SECRET_KEY, db 等已从请求或配置中获取    email = "test@example.com" # 示例值    SECRET_KEY = "your_secret_key" # 示例值    # 模拟用户ID和token生成    userId = "some_user_id" # 假设从db['users'].find()获取    tokenId = "some_jwt_token" # jwt.encode({'userId': userId}, SECRET_KEY, algorithm='HS256')    mensagem = {'message': f'Welcome to the CharTwo {email}!', 'tokenId': tokenId}    # 1. 创建响应对象    response = make_response(jsonify(mensagem))    # 2. 在响应对象上设置Cookie    response.set_cookie('accessToken', tokenId, httponly=True, secure=True, samesite='Lax') # 添加更多安全属性    # 3. 错误:返回了一个新的JSON响应,而非带有Cookie的响应对象    return jsonify(mensagem) # ❌ 错误所在!

错误原因解释:上述loginAccount函数的问题在于最后一行。虽然代码通过make_response(jsonify(mensagem))创建了一个response对象并在其上成功调用了set_cookie(),但最终返回的却是jsonify(mensagem)。jsonify(mensagem)会创建一个全新的Response对象,其中不包含之前在response对象上设置的任何Cookie信息。因此,带有Cookie的response对象被创建后却未被返回,导致Cookie未能发送到客户端。

3. 解决方案:返回正确的响应对象

解决上述问题的关键在于确保返回的是那个已经设置了Cookie的Response对象。

# user.py (修正后的示例)from flask import make_response, jsonify # 假设 db 和 jwt 等已导入和配置def loginAccount():    # 假设 email, SECRET_KEY, db 等已从请求或配置中获取    email = "test@example.com" # 示例值    SECRET_KEY = "your_secret_key" # 示例值    # 模拟用户ID和token生成    userId = "some_user_id" # 假设从db['users'].find()获取    tokenId = "some_jwt_token" # jwt.encode({'userId': userId}, SECRET_KEY, algorithm='HS256')    mensagem = {'message': f'Welcome to the CharTwo {email}!', 'tokenId': tokenId}    # 1. 创建响应对象    response = make_response(jsonify(mensagem))    # 2. 在响应对象上设置Cookie    response.set_cookie('accessToken', tokenId, httponly=True, secure=True, samesite='Lax') # 推荐添加安全属性    # 3. 正确:返回带有Cookie的响应对象    return response # ✅ 修正此处!

通过将return jsonify(mensagem)修改为return response,我们确保了包含accessToken Cookie的Response对象被正确地发送回客户端,浏览器便能接收并存储该Cookie。

立即学习“前端免费学习笔记(深入)”;

4. 前端配置要点:Axios withCredentials

当前端和后端部署在不同域(即跨域)时,为了让浏览器在跨域请求中发送和接收Cookie,前端请求库需要进行特定配置。以Axios为例,必须设置withCredentials: true。

// VueJS 前端代码示例const apiUrl = 'http://127.0.0.1:5000' // 后端API地址axios  .post(    `${apiUrl}/api/account/login`,    {      email: this.email,      password: this.password,    },    {      withCredentials: true, // 关键:允许跨域请求发送和接收Cookie    }  )  .then((response) => {    alert(response.data.message);    console.log(response);  })  .catch((error) => {    alert(`${error.response.data.erro}`);    console.log(error);  });

5. CORS配置:确保跨域Cookie传输

除了前端的withCredentials设置,后端也必须正确配置CORS(跨域资源共享)以允许Cookie的传输。对于Flask应用,通常使用flask-cors扩展。

# main.py (CORS配置)from flask import Flaskfrom flask_cors import CORS, cross_originapp = Flask(__name__)# 允许所有源(或指定源),并支持凭据(包括Cookie)CORS(app, supports_credentials=True)@app.route('/api/account/login', methods=['POST'])# 针对特定路由再次确认支持凭据@cross_origin(supports_credentials=True)def login_account():    # ...    pass

supports_credentials=True是关键,它会设置Access-Control-Allow-Credentials: true响应头,告知浏览器允许携带和接收凭据(如Cookie)。同时,Access-Control-Allow-Origin头不能设置为*,而必须是具体的源地址(或动态设置),因为当supports_credentials为True时,Allow-Origin不能是通配符。

6. Cookie安全与最佳实践

在设置Cookie时,为了提高安全性,建议添加以下属性:

httponly=True:防止客户端JavaScript访问Cookie,降低XSS攻击风险。secure=True:确保Cookie只通过HTTPS连接发送,防止中间人攻击。在开发环境(HTTP)下测试时可能需要暂时禁用或注意,但在生产环境务必开启。samesite=’Lax’ 或 ‘Strict’:防止CSRF(跨站请求伪造)攻击。’Lax’:默认值,允许顶级导航和GET请求发送Cookie,但POST请求通常不允许。’Strict’:最严格,只允许同站请求发送Cookie。’None’:允许跨站请求发送Cookie,但必须同时设置secure=True。如果需要跨域发送Cookie,且源站与目标站不同,可能需要考虑此选项,但应谨慎使用。

response.set_cookie('accessToken', tokenId, httponly=True, secure=True, samesite='Lax')

总结

在Flask中正确设置Cookie并确保前端能够接收,需要注意以下几个关键点:

返回正确的响应对象:务必返回那个在其中调用了set_cookie()方法的Response对象。前端withCredentials:对于跨域请求,前端(如Axios)必须设置withCredentials: true。后端CORS配置:Flask-CORS必须配置supports_credentials=True,并且Access-Control-Allow-Origin不能为*。Cookie安全属性:利用httponly、secure和samesite等属性增强Cookie的安全性。

遵循这些实践,可以有效解决Flask应用中Cookie设置不生效的问题,并构建更健壮、安全的Web服务。

以上就是Flask跨域Cookie设置:确保前端正确接收的实践指南的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1371688.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月14日 11:39:51
下一篇 2025年12月14日 11:39:58

相关推荐

  • Flask set_cookie 不生效:深入解析与正确实践

    本文深入探讨Flask中set_cookie不生效的常见问题,特别是当开发者尝试在返回JSON数据时设置Cookie。核心问题在于未正确返回通过make_response创建并添加了Cookie的响应对象。教程将详细解释这一机制,提供正确的代码示例,并强调在Flask应用中处理响应和Cookie的关…

    好文分享 2025年12月14日
    000
  • AWS Lambda文件系统权限与/tmp目录使用指南

    AWS Lambda的执行环境文件系统大部分是只读的,导致尝试写入非指定区域时会遇到权限错误。唯一可供函数写入的区域是/tmp目录,它提供512 MB至10,240 MB的临时存储空间,并能在执行环境冻结时保留内容,作为跨调用缓存。理解并正确使用/tmp目录是处理Lambda函数临时文件操作的关键。…

    2025年12月14日
    000
  • Python怎么将元组(tuple)转换为列表_Python元组与列表类型转换

    元组转列表可用list()函数实现,创建新列表复制元组元素,原元组不变;因列表可变而元组不可变,转换常用于需修改数据的场景。 将Python中的元组(tuple)转换为列表(list)非常直接,最常用的方法是利用内置的 list() 构造函数。你只需将元组作为参数传递给 list() ,它就会返回一…

    2025年12月14日
    000
  • Python怎么创建文件夹_os模块与Pathlib库文件夹创建

    最直接有效的方式是使用os.makedirs()或pathlib.Path.mkdir(),两者均支持创建多级目录并处理已存在情况。推荐使用pathlib,因其面向对象、跨平台且语法简洁,结合parents=True和exist_ok=True可安全实现幂等创建。 在Python中创建文件夹,最直接…

    2025年12月14日
    000
  • Plotly与ipywidgets在VS Code中实现动态图表更新的策略

    在使用VS Code的Jupyter Notebook中结合Plotly和ipywidgets创建交互式图表时,常见的挑战是每次交互操作都会生成新的图表而非更新现有图表。本文旨在提供一个清晰的解决方案:通过初始化并一次性显示Plotly图表对象,然后在交互回调函数中仅修改该图表的数据或布局,从而实现…

    2025年12月14日
    000
  • 在VS Code中解决Plotly与ipywidgets交互图表重复生成问题

    在VS Code Jupyter Notebook中使用Plotly和ipywidgets时,图表无法原地更新而反复生成新图的问题是一个常见的困扰。核心方案是利用Plotly的FigureWidget,通过在外部初始化图表对象并动态修改其数据和布局,而非每次都创建新图并调用show(),从而实现图表…

    2025年12月14日
    000
  • IntelliJ Python 项目无法浏览库源码的解决方案

    第一段引用上面的摘要:在使用 IntelliJ IDEA 进行 Python 开发时,有时会遇到无法浏览已安装的 Python 库源码的问题。本文提供了一种解决方案,通过重新配置项目 SDK 和模块,解决 IntelliJ IDEA 无法识别项目虚拟环境,导致无法浏览库源码的问题。 在使用 Inte…

    2025年12月14日
    000
  • python怎么反转一个字符串或列表_python字符串与列表反转方法

    最直接的方法是使用切片[::-1],它适用于字符串和列表,创建逆序副本;列表还可使用reverse()方法原地反转,或reversed()函数返回迭代器。 在Python中反转字符串或列表,最直接也最Pythonic的方法通常是利用切片操作 [::-1] 。对于列表,我们还可以使用其内置的 reve…

    2025年12月14日
    000
  • PyTorch模型导出ONNX:在无PyTorch环境中高效推理

    本文介绍如何在不依赖PyTorch的环境中部署和运行PyTorch训练的模型。针对软件依赖限制,核心方案是利用PyTorch的ONNX导出功能,将模型转换为通用ONNX格式。这使得模型能在轻量级运行时(如ONNX Runtime)中高效执行推理,从而避免在部署环境中安装庞大的PyTorch库,实现模…

    2025年12月14日
    000
  • 解决Flask中Cookie设置不生效的常见陷阱与最佳实践

    在Flask应用开发中,开发者常遇到尝试设置Cookie却发现浏览器未接收到的问题。本文将深入剖析这一常见陷阱,指出问题通常源于错误地返回了jsonify对象而非经过make_response处理并附加了Cookie的响应对象。通过理解Flask的响应机制,并提供正确的代码示例和注意事项,确保您的C…

    2025年12月14日
    000
  • Tkinter游戏开发:构建“寻找钻石”并避免常见事件绑定陷阱

    本文将指导您使用Python Tkinter库构建一个名为“寻找钻石”的简单桌面游戏。我们将从游戏界面的创建、逻辑实现到事件处理进行详细讲解,并着重分析一个常见的程序启动失败原因——函数名大小写错误,同时提供优化代码结构、减少重复操作的专业实践方法,助您编写更健壮、可维护的Tkinter应用。 一、…

    2025年12月14日
    000
  • FastAPI依赖注入TypeError:Depends函数调用错误解析与修正

    在FastAPI中,当使用Depends进行依赖注入时,如果错误地调用了作为依赖的函数(例如,将get_db()而非get_db传递给Depends),会导致TypeError: is not a callable object。本文将深入解析此错误的原因,并提供正确的用法,确保您的FastAPI应…

    2025年12月14日
    000
  • 解决Tkinter应用启动失败:Python事件绑定中的大小写问题

    本文深入探讨了在Python Tkinter应用开发中,因事件处理器函数名称大小写不匹配导致的程序启动失败问题。通过一个“藏钻石”游戏实例,详细分析了这一常见陷阱,并提供了精确的修复方案。教程还进一步介绍了如何优化Tkinter事件绑定,提升代码的可维护性和可读性,帮助开发者避免类似错误,构建更健壮…

    2025年12月14日
    000
  • Python __del__方法与对象复活:深入理解终结器行为及替代方案

    本文深入探讨Python中__del__方法在对象生命周期中的作用,特别关注对象“复活”现象及其对__del__调用行为的影响。我们将解释为何在某些情况下,即使对象被复活,其__del__方法也不会被二次调用,尤其是在CPython解释器关闭时。文章还提供了示例代码,并强调了使用__del__的潜在…

    2025年12月14日
    000
  • AWS Lambda文件系统权限管理与/tmp目录最佳实践

    AWS Lambda函数在执行时,其文件系统大部分区域是只读的,这导致常见的“Read-only file system”错误。本文将深入探讨Lambda的这一特性,明确指出用户无法更改文件系统权限。同时,我们将重点介绍/tmp目录作为Lambda环境中唯一的、可用于临时存储和缓存的可写空间,并提供…

    2025年12月14日
    000
  • 深入理解 Python __del__ 方法与对象复活机制

    Python的__del__方法用于对象销毁前的清理工作,但其行为在对象被“复活”(即在__del__执行期间创建新引用)时变得复杂且具有平台特异性。尤其在CPython中,被复活的对象在解释器关闭时不会再次调用__del__。本文将深入探讨这一机制,揭示其潜在问题,并提供使用上下文管理器或atex…

    2025年12月14日
    000
  • Python教程:高效移除JSON数据中的NaN值

    本教程旨在解决JSON数据中 NaN (Not a Number) 值的清洗问题。我们将深入探讨 NaN 在Python中的特殊性及其识别挑战,并提供一个基于 math.isnan() 的高效Python解决方案,实现从字典或JSON对象中精确移除 float(‘nan’) …

    2025年12月14日
    000
  • python beautifulsoup如何解析html_BeautifulSoup解析HTML文档教程

    BeautifulSoup解析HTML的核心是将HTML转化为可操作的Python对象,通过find、find_all及select等方法结合标签、属性和CSS选择器精准提取数据。 BeautifulSoup在Python中解析HTML的核心在于其能够将复杂的HTML结构转化为易于操作的Python…

    2025年12月14日
    000
  • 处理Google Generative AI API限流与数据持久化实践

    本文旨在指导开发者在使用Google Generative AI API(原PaLM API)时,如何有效应对429限流错误、实现数据持久化与错误恢复。我们将探讨官方API的优势,提供实用的限流策略如时间延迟和指数退避,并演示如何在数据处理过程中实时保存结果。通过详细的代码示例和最佳实践,帮助您构建…

    2025年12月14日
    000
  • Abjad中X形符头(Dead Notes)的正确实现方法

    本文旨在解决在Abjad中创建X形符头(即“死音符”)时遇到的常见语法问题。我们将指出用户尝试使用xNote时遇到的LilyPondParser can not emulate music function: xNote错误,并详细介绍如何通过LilyPond的正确命令xNotesOn和xNotes…

    2025年12月14日
    000

发表回复

登录后才能评论
关注微信