同源政策和提取请求

小阪马里子

在此 Codelab 中,您将了解同源在提取资源时的运作方式。

设置:从同一来源提取网页

此演示托管在以下位置:https://same-origin-policy-fetch.glitch.me。这个简单的网页使用 fetchhttps://same-origin-policy-fetch.glitch.me/fetch.html 加载资源。由于 index.htmlfetch.html 同源,因此您应该会在实时预览中看到 200

1. 从其他来源提取网页

尝试将提取网址更改为 https://www.google.com。 您在实时预览中看到了什么?

浏览器应该阻止了提取请求,因为您从其他来源请求了资源。这意味着,即使攻击者控制了用户的浏览器,也无法读取跨源资源。

2. 提取跨源资源

请尝试将提取网址更改为 https://api.thecatapi.com/v1/images/search。 您在实时预览中看到了什么?

提取网址是另一个来源,但您应该会看到状态代码 200。变化原因 现代 Web 应用通常会请求跨源资源以加载第三方脚本或查询 API 端点。为了适应这些用例,我们采用一种称为 CORS(跨域资源共享)的机制,告知浏览器允许加载跨域资源。如需详细了解 CORS,请参阅安全地共享跨域资源