跨域请求和同源策略

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

相关文章

Spring Boot Controller处理HTTP请求体的方法

《SpringBootController处理HTTP请求体的方法》SpringBoot提供了强大的机制来处理不同Content-Type​的HTTP请求体,这主要依赖于HttpMessageCo... 目录一、核心机制:HttpMessageConverter​二、按Content-Type​处理详解1.

一文详解如何在Vue3中封装API请求

《一文详解如何在Vue3中封装API请求》在现代前端开发中,API请求是不可避免的一部分,尤其是与后端交互时,下面我们来看看如何在Vue3项目中封装API请求,让你在实现功能时更加高效吧... 目录为什么要封装API请求1. vue 3项目结构2. 安装axIOS3. 创建API封装模块4. 封装API请求

Redis中6种缓存更新策略详解

《Redis中6种缓存更新策略详解》Redis作为一款高性能的内存数据库,已经成为缓存层的首选解决方案,然而,使用缓存时最大的挑战在于保证缓存数据与底层数据源的一致性,本文将介绍Redis中6种缓存更... 目录引言策略一:Cache-Aside(旁路缓存)策略工作原理代码示例优缺点分析适用场景策略二:Re

SpringBoot请求参数接收控制指南分享

《SpringBoot请求参数接收控制指南分享》:本文主要介绍SpringBoot请求参数接收控制指南,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Spring Boot 请求参数接收控制指南1. 概述2. 有注解时参数接收方式对比3. 无注解时接收参数默认位置

SpringBoot基于配置实现短信服务策略的动态切换

《SpringBoot基于配置实现短信服务策略的动态切换》这篇文章主要为大家详细介绍了SpringBoot在接入多个短信服务商(如阿里云、腾讯云、华为云)后,如何根据配置或环境切换使用不同的服务商,需... 目录目标功能示例配置(application.yml)配置类绑定短信发送策略接口示例:阿里云 & 腾

Spring 请求之传递 JSON 数据的操作方法

《Spring请求之传递JSON数据的操作方法》JSON就是一种数据格式,有自己的格式和语法,使用文本表示一个对象或数组的信息,因此JSON本质是字符串,主要负责在不同的语言中数据传递和交换,这... 目录jsON 概念JSON 语法JSON 的语法JSON 的两种结构JSON 字符串和 Java 对象互转

redis过期key的删除策略介绍

《redis过期key的删除策略介绍》:本文主要介绍redis过期key的删除策略,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录第一种策略:被动删除第二种策略:定期删除第三种策略:强制删除关于big key的清理UNLINK命令FLUSHALL/FLUSHDB命

SpringMVC获取请求参数的方法

《SpringMVC获取请求参数的方法》:本文主要介绍SpringMVC获取请求参数的方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下... 目录1、通过ServletAPI获取2、通过控制器方法的形参获取请求参数3、@RequestParam4、@

SpringRetry重试机制之@Retryable注解与重试策略详解

《SpringRetry重试机制之@Retryable注解与重试策略详解》本文将详细介绍SpringRetry的重试机制,特别是@Retryable注解的使用及各种重试策略的配置,帮助开发者构建更加健... 目录引言一、SpringRetry基础知识二、启用SpringRetry三、@Retryable注解

MySQL 分区与分库分表策略应用小结

《MySQL分区与分库分表策略应用小结》在大数据量、复杂查询和高并发的应用场景下,单一数据库往往难以满足性能和扩展性的要求,本文将详细介绍这两种策略的基本概念、实现方法及优缺点,并通过实际案例展示如... 目录mysql 分区与分库分表策略1. 数据库水平拆分的背景2. MySQL 分区策略2.1 分区概念