news 2026/4/23 10:50:44

Python中CORS 跨域中间件的配置和作用原理

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Python中CORS 跨域中间件的配置和作用原理

一、先定位是什么:

CORS(Cross-Origin Resource Sharing)跨域资源共享,是由浏览器和服务端共同遵循的、规范跨域 HTTP 请求行为的安全机制

它的核心作用是在浏览器 “同源策略” 的安全框架下,允许服务端通过配置响应头明确声明 “哪些源(域名 + 端口)、哪些操作(方法 / 头信息)可以跨域访问自身资源”,从而解决同源策略过于严格导致的合法业务跨域需求问题。

二、为什么?

就是因为浏览器本身有一个叫同源策略的安全机制:

当前端页面的协议、域名、端口与后端 API 的协议、域名、端口不一致时,浏览器会在接收后端响应后拦截数据;而 CORS(跨域资源共享)通过服务端配置响应头,让浏览器判定该跨域请求合法,从而放行响应数据,解决同源策略导致的跨域拦截问题。

三、怎么解决?

CORS 通过让服务器在 HTTP 响应头中注入标准化的 CORS 响应头来告诉浏览器:哪些源(Origin)哪些操作可以跨域访问资源

而不同语言配置 CORS 响应头的方法都不一样,java中是通过实现WebMvcConfigurer接口重写addCorsMappings方法来实现的。而我们的python则使用
跨域资源共享中间件:CORSMiddleware

它的的核心作用就是在HTTP响应中注入CORS相关头信息,让浏览器放行跨域请求。

from fastapi import FastAPI from fastapi.middleware.cors import CORSMiddleware app = FastAPI() # 配置允许跨域的源(生产环境替换为具体域名) origins = [ "http://localhost:3000", # 前端本地开发地址 "https://www.xxx.com", # 生产环境前端域名 "https://admin.xxx.com", # 多域名支持 ] # 添加跨域中间件 app.add_middleware( CORSMiddleware, allow_origins=origins, # 允许的跨域源(列表形式,支持多个) allow_credentials=True, # 是否允许携带 Cookie(关键,默认 False) allow_methods=["*"], # 允许的请求方法(* 表示所有,如 GET/POST/PUT/DELETE) allow_headers=["*"], # 允许的请求头(* 表示所有,如 Token/Content-Type) max_age=3600, # 预检请求(OPTIONS)的缓存时间(秒),避免频繁预检 ) # 测试接口 @app.get("/api/test") async def test_cors(): return {"msg": "FastAPI 跨域请求成功"} if __name__ == "__main__": import uvicorn uvicorn.run(app, host="0.0.0.0", port=8000)

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 10:50:43

Excalidraw是否支持离线使用?PWA功能评测

Excalidraw 是否支持离线使用?PWA 功能深度评测 在如今这个远程协作常态化、信息碎片化加剧的时代,一个能随时打开、快速记录灵感的数字白板,几乎成了每位技术人员的“电子便签”。而当会议突然开始、地铁钻入隧道、或者身处没有Wi-Fi的会议…

作者头像 李华
网站建设 2026/4/20 22:59:26

Excalidraw issue响应速度与bug修复周期统计

Excalidraw issue响应速度与bug修复周期统计 在开源项目的世界里,一个仓库的“活跃度”往往不是看 star 数或 fork 量,而是藏在那些不起眼的细节中——比如你提了一个 issue 后,多久才有人回你?一个 bug 被报告后,要等…

作者头像 李华
网站建设 2026/4/21 20:48:47

夸克限速_网盘解析

今天教大家一招能解决夸克网盘限制的在线工具。这个工具也是完全免费使用的。下面让大家看看我用这个工具的下载速度咋样。地址获取:放在这里了,可以直接获取 这个速度还是不错的把。对于平常不怎么下载的用户还是很友好的。下面开始今天的教学 输入我给…

作者头像 李华
网站建设 2026/4/16 21:48:04

12、Windows XP界面操作指南

Windows XP界面操作指南 1. 对话框操作 在Windows XP中,对话框是与系统进行交互的重要工具。不同类型的按钮在对话框中有不同的功能: - 带省略号(…)的命令按钮 :点击此类按钮会弹出另一个对话框。 - 带两个大于号(>)的命令按钮 :选择该按钮会扩展当前对话框…

作者头像 李华
网站建设 2026/4/18 5:41:13

21、Windows系统实用工具与控制面板使用指南

Windows系统实用工具与控制面板使用指南 在使用Windows系统的过程中,有许多实用的工具和功能可以帮助我们更好地管理和使用计算机。下面将为大家详细介绍系统还原、Windows资源管理器、Windows Movie Maker、写字板以及Windows控制面板等重要内容。 系统还原 系统还原功能允…

作者头像 李华
网站建设 2026/4/22 13:40:08

Excalidraw + GPU算力加速:实现AI绘图实时响应

Excalidraw GPU算力加速:实现AI绘图实时响应 在远程协作日益成为常态的今天,团队对可视化工具的要求早已不再局限于“能画图”。无论是技术架构讨论、产品原型设计,还是敏捷会议中的即兴草图,人们期待的是一个既直观又智能、既能…

作者头像 李华