什么情况下会发生跨域

跨域的本质是浏览器的同源策略 限制,当请求的目标资源与当前页面的协议、域名(主机)、端口三者中任意一个不相同,就会触发跨域。

1. 同源的判定标准

只有当两个资源的协议域名(主机名)端口 完全一致时,才属于 "同源",否则即为跨域。例如,当前页面地址为http://www.example.com:8080

  • 同源地址:http://www.example.com:8080/page.html(三者均一致)
  • 非同源地址:只要协议、域名、端口任一不同,都算跨域。

2. 常见的跨域场景

(1)协议不同
  • 当前页面:http://www.example.com
  • 请求目标:https://www.example.com(http 与 https 协议不同)
(2)域名不同

这是最常见的跨域类型,包含多种子场景:

  1. 主域名不同
    • 当前页面:http://www.example.com
    • 请求目标:http://www.test.com(example 和 test 为主域名,完全不同)
  2. 子域名不同
    • 当前页面:http://www.example.com
    • 请求目标:http://api.example.com(www 和 api 为不同子域名)
  3. 域名与 IP 不同
    • 当前页面:http://localhost
    • 请求目标:http://127.0.0.1localhost和 127.0.0.1 虽指向同一主机,但浏览器判定为不同域名)
(3)端口不同

HTTP 默认端口为 80,HTTPS 默认端口为 443,只要端口号不一致即跨域:

  • 当前页面:http://www.example.com:8080
  • 请求目标:http://www.example.com:8081(8080 和 8081 端口不同)
(4)特殊的跨域场景
  1. 跨域资源嵌入的特殊情况
    • <img><script><link>这类标签加载的资源(如图片、js 文件、css 文件),本身不会触发跨域拦截,但通过这些资源发起的数据交互(如 script 的回调、img 的加载状态传递数据)可能受同源策略限制;
  2. iframe 跨域通信
    • 当父页面和 iframe 内页面不同源时,二者无法直接通过 js 进行 DOM 操作或数据通信。

3. 跨域的核心影响

跨域限制仅存在于浏览器端 ,服务器与服务器之间的请求不受同源策略约束;浏览器的跨域拦截主要针对XMLHttpRequestFetch等 AJAX 类请求,目的是保护用户的 Cookie、Session 等敏感信息不被恶意网站窃取。

相关推荐
我是唐青枫6 小时前
C#.NET gRPC 深入解析:Proto 定义、流式调用与服务间通信取舍
开发语言·c#·.net
unicrom_深圳市由你创科技7 小时前
做虚拟示波器这种实时波形显示的上位机,用什么语言?
c++·python·c#
昵称暂无17 小时前
.NET 高级开发 | i18n 原理、实现一个 i18n 框架
javascript·c#·.net
疯狂成瘾者8 小时前
Chroma向量数据库
开发语言·数据库·c#
我是唐青枫8 小时前
C#.NET Monitor 与 Mutex 深入解析:进程内同步、跨进程互斥与使用边界
开发语言·c#·.net
ou.cs8 小时前
c# 信号量和锁的区别
开发语言·c#
yugi9878388 小时前
C# 串口下载烧写BIN文件工具
开发语言·c#
"菠萝"10 小时前
C#知识学习-021(文字关键字)
开发语言·学习·c#
游乐码10 小时前
c#HashTable
开发语言·c#
游乐码10 小时前
C#Queue
数据结构·游戏·c#