跨域请求和同源策略

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 filter实现请求响应全链路拦截

《springbootfilter实现请求响应全链路拦截》这篇文章主要为大家详细介绍了SpringBoot如何结合Filter同时拦截请求和响应,从而实现​​日志采集自动化,感兴趣的小伙伴可以跟随小... 目录一、为什么你需要这个过滤器?​​​二、核心实现:一个Filter搞定双向数据流​​​​三、完整代码

AJAX请求上传下载进度监控实现方式

《AJAX请求上传下载进度监控实现方式》在日常Web开发中,AJAX(AsynchronousJavaScriptandXML)被广泛用于异步请求数据,而无需刷新整个页面,:本文主要介绍AJAX请... 目录1. 前言2. 基于XMLHttpRequest的进度监控2.1 基础版文件上传监控2.2 增强版多

Springboot处理跨域的实现方式(附Demo)

《Springboot处理跨域的实现方式(附Demo)》:本文主要介绍Springboot处理跨域的实现方式(附Demo),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不... 目录Springboot处理跨域的方式1. 基本知识2. @CrossOrigin3. 全局跨域设置4.

SpringBoot使用OkHttp完成高效网络请求详解

《SpringBoot使用OkHttp完成高效网络请求详解》OkHttp是一个高效的HTTP客户端,支持同步和异步请求,且具备自动处理cookie、缓存和连接池等高级功能,下面我们来看看SpringB... 目录一、OkHttp 简介二、在 Spring Boot 中集成 OkHttp三、封装 OkHttp

SpringBoot如何通过Map实现策略模式

《SpringBoot如何通过Map实现策略模式》策略模式是一种行为设计模式,它允许在运行时选择算法的行为,在Spring框架中,我们可以利用@Resource注解和Map集合来优雅地实现策略模式,这... 目录前言底层机制解析Spring的集合类型自动装配@Resource注解的行为实现原理使用直接使用M

Go语言中最便捷的http请求包resty的使用详解

《Go语言中最便捷的http请求包resty的使用详解》go语言虽然自身就有net/http包,但是说实话用起来没那么好用,resty包是go语言中一个非常受欢迎的http请求处理包,下面我们一起来学... 目录安装一、一个简单的get二、带查询参数三、设置请求头、body四、设置表单数据五、处理响应六、超

Spring MVC跨域问题及解决

《SpringMVC跨域问题及解决》:本文主要介绍SpringMVC跨域问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录跨域问题不同的域同源策略解决方法1.CORS2.jsONP3.局部解决方案4.全局解决方法总结跨域问题不同的域协议、域名、端口

Redis 内存淘汰策略深度解析(最新推荐)

《Redis内存淘汰策略深度解析(最新推荐)》本文详细探讨了Redis的内存淘汰策略、实现原理、适用场景及最佳实践,介绍了八种内存淘汰策略,包括noeviction、LRU、LFU、TTL、Rand... 目录一、 内存淘汰策略概述二、内存淘汰策略详解2.1 ​noeviction(不淘汰)​2.2 ​LR

Qt实现发送HTTP请求的示例详解

《Qt实现发送HTTP请求的示例详解》这篇文章主要为大家详细介绍了如何通过Qt实现发送HTTP请求,文中的示例代码讲解详细,具有一定的借鉴价值,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1、添加network模块2、包含改头文件3、创建网络访问管理器4、创建接口5、创建网络请求对象6、创建一个回复对

SpringBoot项目注入 traceId 追踪整个请求的日志链路(过程详解)

《SpringBoot项目注入traceId追踪整个请求的日志链路(过程详解)》本文介绍了如何在单体SpringBoot项目中通过手动实现过滤器或拦截器来注入traceId,以追踪整个请求的日志链... SpringBoot项目注入 traceId 来追踪整个请求的日志链路,有了 traceId, 我们在排