CORS 如果需要指定多个域名怎么办
CORS
通过控制 Access-Control-Allow-Origin
控制哪些域名可以共享资源,取值如下
Access-Control-Allow-Origin: <origin> | *
其中 *
代表所有域名,origin
代表指定特定域名,那如何设置多个域名了?
此时需要通过代码实现,根据请求头中的 Origin
来设置响应头 Access-Control-Allow-Origin
,那 Origin 又是什么东西?
请求头: Origin
并不是所有请求都会自动带上 Origin
,在浏览器中带 Origin
的逻辑如下
- 如果存在跨域,则带上
Origin
,值为当前域名 - 如果不存在跨域,则不带
Origin
逻辑理清楚后,关于服务器中对于 Access-Control-Allow-Origin
设置多域名的逻辑也很清晰了
- 如果请求头不带有
Origin
,证明未跨域,则不作任何处理 - 如果请求头带有
Origin
,证明跨域,根据Origin
设置相应的Access-Control-Allow-Origin: <Origin>
使用伪代码实现如下:
// 获取 Origin 请求头 const requestOrigin = ctx.get('Origin'); // 如果没有,则跳过 if (!requestOrigin) { return await next(); } // 设置响应头 ctx.set('Access-Control-Allow-Origin', requestOrigin)
Vary: Origin
此时可以给多个域名控制 CORS,但此时假设有两个域名访问 static.shanyue.tech
的跨域资源
foo.shanyue.tech
,响应头中返回Access-Control-Allow-Origin: foo.shanyue.tech
bar.shanyue.tech
,响应头中返回Access-Control-Allow-Origin: bar.shanyue.tech
看起来一切正常,但如果中间有缓存怎么办?
foo.shanyue.tech
,响应头中返回Access-Control-Allow-Origin: foo.shanyue.tech
,被 CDN 缓存bar.shanyue.tech
,因由缓存,响应头中返回Access-Control-Allow-Origin: foo.shanyue.tech
,跨域出现问题
此时,Vary: Origin
就上场了,代表为不同的 Origin
缓存不同的资源
总结 (简要答案)
CORS 如何指定多个域名?
根据请求头中的 Origin
来设置响应头 Access-Control-Allow-Origin
,思路如下
- 总是设置
Vary: Origin
,避免 CDN 缓存破坏 CORS 配置 - 如果请求头不带有
Origin
,证明未跨域,则不作任何处理 - 如果请求头带有
Origin
,证明浏览器访问跨域,根据Origin
设置相应的Access-Control-Allow-Origin: <Origin>
使用伪代码实现如下
// 获取 Origin 请求头 const requestOrigin = ctx.get('Origin'); ctx.set('Vary', 'Origin') // 如果没有,则跳过 if (!requestOrigin) { return await next(); } // 设置响应头 ctx.set('Access-Control-Allow-Origin', requestOrigin)
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库