同源和跨域

本文详细介绍了浏览器的同源策略和跨域的概念,包括它们的定义和比较示例。同源策略要求协议、域名和端口一致,而跨域则发生在这些元素不匹配的情况。通过多个案例分析,阐述了不同场景下同源和跨域的判断标准,帮助读者深入理解这两个关键的网络概念。
摘要由CSDN通过智能技术生成

同源和跨域

1. 概述

  • 同源策略:
    • 同域名,同端口,同协议
  • 简单来说,就是违反了同源策略的请求,就是跨域
  • 跨域:
    • 跨域名,跨端口,跨协议
  • 浏览器要求在解析Ajax请求时,浏览器的路径与Ajax的请求的路径,必须满足同源策略。同源就是协议、域名和端口三者必须一致。
  • 比较的是
    • 浏览器的请求路径 和 Ajax的请求网址

2. 比较示例

  • 案例一:
    • 浏览器地址:http://localhost:8080/findAll
    • Ajax请求地址:http://localhost:8080/aaa
    • 满足同源策略,服务器可以访问
  • 案例二:
    • 浏览器地址:http://localhost:8081/findAll
    • Ajax请求地址:http://localhost:8080/aaa
    • 不满足同源策略,端口号不一样,属于跨域请求
  • 案例三:
    • 浏览器地址:http://localhost:8080/findAll
    • Ajax请求地址:https://localhost:8080/aaa
    • 不满足同源策略,协议不一样,属于跨域请求
  • 案例四:
    • 前提: IP与域名映射
    • 浏览器地址:http://www.baidu.com:8080/findAll
    • Ajax请求地址:http://10.0.1.1:8080/aaa
    • 不满足同源策略
      • 虽然写IP和域名理论上是一样的,域名的ASCII码不一样
  • 案例五:
    • 浏览器地址:http://10.0.1.1:80/findAll
    • Ajax请求地址:http://10.0.1.1/aaa
    • 满足同源策略,可以访问
      • 看似不满足同源策略,一个有端口号,一个没有,但是不写端口号时,浏览器会默认给他补一个,http 协议的默认端口号是80
  • 案例六:
    • 浏览器地址:https://10.0.1.1:443/findAll
    • Ajax请求地址:https://10.0.1.1/aaa
    • 满足同源策略
      • 看似不满足同源策略,一个有端口号,一个没有,但是不写端口号时,浏览器会默认给他补一个,https 协议的默认端口号是443
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值