什么情况下会发生跨域

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

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 等敏感信息不被恶意网站窃取。

相关推荐
雪豹阿伟1 小时前
21.Winfrom —— 定时器、日期选择器、进度条、表格、DataTable
c#·上位机·winfrom
z落落1 小时前
C#WinForm控件实战:Panel与单选框动态创建
开发语言·c#
qq_422152574 小时前
Word 文件太大怎么压缩?2026 年文档瘦身方案对比
开发语言·c#·word
影寂ldy5 小时前
C# 事件完整学习笔记(发布订阅 + 自定义事件 + 内置 EventHandler)
笔记·学习·c#
kyle~7 小时前
DDS分布式实时系统---自省机制
开发语言·分布式·机器人·c#·接口·ros2
Java面试题总结7 小时前
MarkItDown 再次登顶GitHub榜
开发语言·c#·github
xiaoshuaishuai88 小时前
C# 定制化Markdown编辑器
开发语言·c#·编辑器
yugi9878389 小时前
基于C#实现数字识别率的OCR方案
开发语言·c#·ocr
天天代码码天天9 小时前
OpenCV 5 + PP-OCRv6 + OpenVINO:C# 本地 OCR 推理更快、更稳、更好集成
opencv·c#·openvino
Chris _data11 小时前
c#学习WPF笔记(一)
学习·c#·wpf