跨域请求和同源策略

2024-08-27 22:28
文章标签 请求 策略 跨域 同源

本文主要是介绍跨域请求和同源策略,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 同源策略

1.1. 介绍

同源策略是一种安全机制,限制了从一个源加载的文档或脚本如何与来自另一个源的资源进行交互。

“源” 指:协议(http/https)、主机名(域名)和端口号。这3个有一个不同,就不是同源。

子域名不同,也不是同源,比如a.baidu.com和b.baidu.com不是同源。

1.2. 同源策略的作用

确保浏览器的安全环境,防止恶意网站窃取用户数据、不同源的资源之间的混乱交互。

1.3. 限制范围

  • Cookie、LocalStorage和IndexedDB等存储机制受到同源策略限制。不同源的网页不能读取或修改彼此的这些存储内容。
  • DOM(文档对象模型)访问受同源策略限制。一个网页中的JavaScript不能访问另一个不同源网页的DOM。
  • ajax请求受到同源策略的限制。默认情况下,ajax只能访问同源的资源。

2. 跨域请求

2.1. 介绍

一个网页中的脚本尝试向不同源的服务器发起请求时,就称为跨域请求。例如,网页http://a.com中的脚本向http://b.com发起的请求就是跨域请求。

2.2. 实现方式

2.2.1. CORS(跨源资源共享)

允许服务器通过在响应头中设置特定的字段来告诉浏览器允许来自不同源的请求。

例如,服务器可以设置Access-Control-Allow-Origin响应头来指定允许访问的源。

如果浏览器检测到响应头中包含了允许当前源访问的信息,就会允许该跨域请求成功。

2.2.2. JSONP

利用<script>标签的跨域请求方法。

浏览器允许<script>标签加载不同源的脚本,可以通过动态创建<script>标签并设置其src属性为跨域的 URL,服务器返回一个包含函数调用的JavaScript代码,函数的参数是要返回的数据。当脚本加载完成后,这个函数就会被调用,从而实现跨域数据获取。但JSONP只支持GET请求,且存在安全风险。

2.2.3. 代理服务器

在同源的服务器上设置一个代理,由代理服务器向不同源的服务器发起请求,然后将响应返回给客户端。

3. 同源策略和跨域请求的关系

  • 同源策略是跨域请求面临阻碍的根本原因
  • 跨域请求对同源策略的突破尝试

由于同源策略,浏览器会阻止网页中的脚本向不同源的服务器发起请求。这是为了保护用户的隐私和安全,防止恶意网站通过跨域请求窃取用户数据或进行其他恶意行为。

这篇关于跨域请求和同源策略的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1112953

相关文章

SpringBoot 获取请求参数的常用注解及用法

《SpringBoot获取请求参数的常用注解及用法》SpringBoot通过@RequestParam、@PathVariable等注解支持从HTTP请求中获取参数,涵盖查询、路径、请求体、头、C... 目录SpringBoot 提供了多种注解来方便地从 HTTP 请求中获取参数以下是主要的注解及其用法:1

SpringBoot请求参数传递与接收示例详解

《SpringBoot请求参数传递与接收示例详解》本文给大家介绍SpringBoot请求参数传递与接收示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋... 目录I. 基础参数传递i.查询参数(Query Parameters)ii.路径参数(Path Va

使用Python的requests库来发送HTTP请求的操作指南

《使用Python的requests库来发送HTTP请求的操作指南》使用Python的requests库发送HTTP请求是非常简单和直观的,requests库提供了丰富的API,可以发送各种类型的HT... 目录前言1. 安装 requests 库2. 发送 GET 请求3. 发送 POST 请求4. 发送

MySQL设置密码复杂度策略的完整步骤(附代码示例)

《MySQL设置密码复杂度策略的完整步骤(附代码示例)》MySQL密码策略还可能包括密码复杂度的检查,如是否要求密码包含大写字母、小写字母、数字和特殊字符等,:本文主要介绍MySQL设置密码复杂度... 目录前言1. 使用 validate_password 插件1.1 启用 validate_passwo

Python实现网格交易策略的过程

《Python实现网格交易策略的过程》本文讲解Python网格交易策略,利用ccxt获取加密货币数据及backtrader回测,通过设定网格节点,低买高卖获利,适合震荡行情,下面跟我一起看看我们的第一... 网格交易是一种经典的量化交易策略,其核心思想是在价格上下预设多个“网格”,当价格触发特定网格时执行买

python运用requests模拟浏览器发送请求过程

《python运用requests模拟浏览器发送请求过程》模拟浏览器请求可选用requests处理静态内容,selenium应对动态页面,playwright支持高级自动化,设置代理和超时参数,根据需... 目录使用requests库模拟浏览器请求使用selenium自动化浏览器操作使用playwright

SpringBoot监控API请求耗时的6中解决解决方案

《SpringBoot监控API请求耗时的6中解决解决方案》本文介绍SpringBoot中记录API请求耗时的6种方案,包括手动埋点、AOP切面、拦截器、Filter、事件监听、Micrometer+... 目录1. 简介2.实战案例2.1 手动记录2.2 自定义AOP记录2.3 拦截器技术2.4 使用Fi

SpringBoot中4种数据水平分片策略

《SpringBoot中4种数据水平分片策略》数据水平分片作为一种水平扩展策略,通过将数据分散到多个物理节点上,有效解决了存储容量和性能瓶颈问题,下面小编就来和大家分享4种数据分片策略吧... 目录一、前言二、哈希分片2.1 原理2.2 SpringBoot实现2.3 优缺点分析2.4 适用场景三、范围分片

Nginx 配置跨域的实现及常见问题解决

《Nginx配置跨域的实现及常见问题解决》本文主要介绍了Nginx配置跨域的实现及常见问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来... 目录1. 跨域1.1 同源策略1.2 跨域资源共享(CORS)2. Nginx 配置跨域的场景2.1

关于跨域无效的问题及解决(java后端方案)

《关于跨域无效的问题及解决(java后端方案)》:本文主要介绍关于跨域无效的问题及解决(java后端方案),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录通用后端跨域方法1、@CrossOrigin 注解2、springboot2.0 实现WebMvcConfig