你可能不知道的CORS跨域资源共享

yizhihongxing

下面是关于CORS跨域资源共享的详细讲解,希望能对你有所帮助。

CORS是什么

CORS(Cross-Origin Resource Sharing)跨域资源共享,是用来解决跨域访问的一种技术。由于浏览器实行同源策略(Same-Origin Policy),如果一个URL的协议、域名和端口都与当前页面的协议、域名和端口相同,则就是同源;否则就是跨域,跨域请求将被浏览器拒绝。

CORS允许浏览器向跨源服务器发送XMLHttpRequest请求,从而克服了同源策略产生的限制。在浏览器向服务器发送请求时,会先发送一个OPTIONS请求,以判断是否允许跨域访问。如果服务器允许,则返回一个带有Access-Control-Allow-Origin头的响应,表示允许当前域名的请求。客户端在收到响应后,再发送真正的请求。

CORS请求的流程

CORS请求的流程如下:

  1. 客户端通过XMLHttpRequest对象发起CORS请求。

  2. 浏览器发现这个请求跨域,会添加一个Origin头信息,表示这个请求来自哪个域名。

  3. 服务端接收到请求并处理,发送一个响应,在响应头中添加Access-Control-Allow-Origin头信息,表示该请求的响应可以被发起请求的源接受。

  4. 浏览器收到响应后,判断是否允许发送该响应内容。如果允许,则把响应内容作为XMLHttpRequest对象的response属性,并触发xhr的onload事件。如果不允许,则返回一个异常。

示例说明

下面给出两个CORS跨域的示例:

示例一:

假设有两个网站:http://a.comhttp://b.com。现在,在 http://a.com 的页面中通过JavaScript代码向 http://b.com 请求数据。由于跨域访问,浏览器会自动发送OPTIONS请求,判断是否允许跨域。所以在 http://b.com 的服务器端代码中,需要添加如下代码:

response.headers["Access-Control-Allow-Origin"] = "http://a.com"

表示允许 http://a.com 域名的请求。

示例二:

假设有两个网站:http://a.comhttp://b.com。现在,在 http://a.com 的页面中通过XMLHttpRequest对象向 http://b.com 请求数据。在服务器端,需要按照如下方式添加响应头:

response.headers["Access-Control-Allow-Origin"] = "http://a.com"
response.headers["Access-Control-Allow-Headers"] = "Content-Type"
response.headers["Access-Control-Allow-Methods"] = "POST, GET, OPTIONS"
  • 第一行表示允许 http://a.com 域名的请求;

  • 第二行表示允许发送Content-Type请求头;

  • 第三行表示允许POST、GET和OPTIONS方法的请求。

总结

CORS是解决跨域问题的一种通用方法,可以实现安全地访问跨域资源。在使用CORS时,需要按照规范添加Access-Control-Allow-*系列响应头信息,来实现对跨域请求的正确响应。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:你可能不知道的CORS跨域资源共享 - Python技术站

(0)
上一篇 2023年6月11日
下一篇 2023年6月11日

相关文章

  • XSS & SQL注入

    XSS和SQL注入是常见的Web攻击方式。本文将从攻击原理、攻击步骤、预防措施等方面详细讲解XSS和SQL注入的攻击流程。 XSS攻击 攻击原理 XSS(Cross-Site Scripting),中文名为跨站脚本攻击。攻击者通过在Web页面中注入恶意脚本,使得用户在访问该页面时误执行恶意脚本,从而导致攻击者可以获取用户的敏感信息或者控制用户的操作。 攻击步…

    JavaScript 2023年6月11日
    00
  • JavaScript面向对象之深入了解ES6的class

    一、JavaScript面向对象JavaScript是一种弱类型语言,不支持类的概念,但是JavaScript可以通过对象、原型和构造函数等方式模拟类的概念。在JavaScript中,对象是一个属性的集合,可以通过点语法或方括号语法来访问对象中的属性和方法。同时,JavaScript还支持原型继承。继承是指对象可以继承其他对象中的属性和方法,这种继承是通过原…

    JavaScript 2023年5月27日
    00
  • JS Jquery 遍历,筛选页面元素 自动完成(实现代码)

    下面是关于JS Jquery遍历、筛选页面元素和实现自动完成的攻略。 什么是Jquery? JQuery是一个快速,小巧且功能强大的JavaScript库。它使得处理HTML文档、事件处理、动画和Ajax等操作更加简单和快捷。JQuery提供了具有出色表现的API集合,这些API可用于访问和修改文档的结构与内容,处理事件、动画以及Ajax操作等。 遍历页面元…

    JavaScript 2023年6月11日
    00
  • 在JavaScript中通过URL传递汉字的方法

    在JavaScript中,我们可以通过URL传递参数,包括传递汉字参数。以下是详细的方法攻略: 第一步:使用encodeURIComponent()方法 在传递参数中包含汉字时,需要使用JavaScript提供的encodeURIComponent()方法对参数进行编码。该方法会把所有非字母数字字符(如汉字)都转换为URL编码,以便能够正确传递。 例如,如果…

    JavaScript 2023年5月19日
    00
  • JS中call apply bind函数手写实现demo

    下面是关于“JS中call apply bind函数手写实现demo”的攻略: 理解call、apply、bind函数 在手写这三个函数的过程中,我们必须先清楚地理解这三个函数的作用: call函数:调用一个函数,将一个对象作为第一个参数,以及多个参数传入该函数。 apply函数:调用一个函数,将一个对象作为第一个参数,以及一个参数数组传入该函数。 bind…

    JavaScript 2023年6月10日
    00
  • 在JavaScript中构建ArrayList示例代码

    在JavaScript中构建ArrayList需要先了解什么是ArrayList。ArrayList是一种动态数组,可以在数组不够长时自动扩展。在JavaScript中,原生数组可以看作是一种最基本的ArrayList,但是缺少了自动扩展的功能。因此,我们需要自己构建一种可以自动扩展的ArrayList。 构建一个ArrayList可以通过定义一个类来实现。…

    JavaScript 2023年5月27日
    00
  • javascript 两种声明函数的方式的分析

    我会为你进行详细的解释。 在JavaScript中有两种声明函数的方式: 函数声明 函数声明的语法如下: function 函数名称 (参数) { // 函数体 } 这种方式声明函数的特点是在代码块执行之前函数就已经存在。也就是说,无论在何处调用函数都是有效的。此外,函数声明不需要使用分号(;)来结束。 下面是一个简单的示例,演示了如何使用函数声明: fun…

    JavaScript 2023年5月27日
    00
  • javascript中break,continue和return语句用法小结

    接下来我将为你详细讲解“JavaScript中break,continue和return语句用法小结”。 1. break语句 在循环结构中,break语句可以让程序停止当前循环并跳出循环结构。在for循环和while循环中,break语句的使用方法相同。 示例1 下面的示例演示如何在for循环中使用break语句,当循环到i为2时,停止循环并跳出循环结构。…

    JavaScript 2023年5月28日
    00
合作推广
合作推广
分享本页
返回顶部