跳至主要內容

跨域资源共享

2024年4月30日大约 3 分钟

跨域资源共享


CORS(跨域资源共享) - FastAPI (tiangolo.com)open in new window

CORS 或者「跨域资源共享」open in new window 指浏览器中运行的前端拥有与后端通信的 JavaScript 代码,而后端处于与前端不同的「源」的情况。


源是协议(httphttps) 、域(myapp.comlocalhostlocalhost.tiangolo.com) 以及端口(804438080) 的组合。

因此,这些都是不同的源:

即使它们都在 localhost 中,但是它们使用不同的协议或者端口,所以它们都是不同的「源」。


步骤

假设你的浏览器中有一个前端运行在 https://localhost:3100,并且它的 JavaScript 正在尝试与运行在 http://localhost:8000 的后端通信

然后,浏览器会向后端发送一个 HTTP OPTIONS 请求,如果后端发送适当的 headers 来授权来自这个不同源(https://localhost:3100) 的通信,浏览器将允许前端的 JavaScript 向后端发送请求。

为此,后端必须有一个「允许的源」列表。

在这种情况下,它必须包含 https://localhost:3100,前端才能正常工作。


通配符

也可以使用 "*"(一个「通配符」) 声明这个列表,表示全部都是允许的。

但这仅允许某些类型的通信,不包括所有涉及凭据的内容:像 Cookies 以及那些使用 Bearer 令牌的授权 headers 等。

因此,为了一切都能正常工作,最好显式地指定允许的源。


使用 CORSMiddleWare

你可以在 FastAPI 应用中使用 CORSMiddleware 来配置它。

你也可以指定后端是否允许:

from fastapi.middleware.cors import CORSMiddleware

origins = [
    "http://localhost",
    "https://localhost",
    "http://localhost:3100",
    "https://localhost:3100",
]

app = FastAPI()

# 跨域资源共享配置
app.add_middleware(
    CORSMiddleware,
    allow_origins=origins,  # 跨域信任列表
    allow_credentials=True, # 允许使用整数
    allow_methods=["*"],    # 允许跨域的方法, *(通配符) 表示全部允许
    allow_headers=["*"],    # 允许的请求头, * 表示全部允许
)

默认情况下,这个 CORSMiddleware 实现所使用的默认参数较为保守,所以你需要显式地启用特定的源、方法或者 headers,以便浏览器能够在跨域上下文中使用它们。

支持以下参数:

中间件响应两种特定类型的 HTTP 请求……


CORS 预检请求

这是些带有 OriginAccess-Control-Request-Method 请求头的 OPTIONS 请求。

在这种情况下,中间件将拦截传入的请求并进行响应,出于提供信息的目的返回一个使用了适当的 CORS headers 的 200400 响应。


简单请求

任何带有 Origin 请求头的请求。在这种情况下,中间件将像平常一样传递请求,但是在响应中包含适当的 CORS headers。