JavaScript高级主题:什么是跨域资源共享(CORS)?

简介: JavaScript高级主题:什么是跨域资源共享(CORS)?

跨域资源共享(CORS) 是一种通过HTTP头来允许在不同源之间进行安全跨域数据访问的机制。由于浏览器的同源策略,通常在跨域请求时会受到限制,CORS 提供了一种标准的方式来让服务器声明哪些来源被允许访问其资源。

CORS 的关键思想是使用 HTTP 头部来传递允许跨域访问的信息。以下是 CORS 的一些关键头部:

  1. Origin(请求来源): 在每个 HTTP 请求头中都包含了一个 Origin 字段,表示请求的来源。

  2. Access-Control-Allow-Origin(允许访问的来源): 服务器通过这个头部告诉浏览器,哪些源是被允许访问资源的。可以是单个源,也可以是用逗号分隔的多个源,甚至可以是通配符 *,表示任何来源。

  3. Access-Control-Allow-Methods(允许的请求方法): 指定了实际请求中允许的方法。例如,GET、POST 等。

  4. Access-Control-Allow-Headers(允许的请求头): 指定了实际请求中允许携带的首部字段。

  5. Access-Control-Expose-Headers(允许访问的响应首部): 指定了哪些首部字段可以作为响应的一部分被访问。

  6. Access-Control-Allow-Credentials(是否允许携带身份凭证): 如果服务器允许请求携带凭证(比如 cookie 或 HTTP 认证信息),则该字段的值设置为 true

  7. Access-Control-Max-Age(预检请求的有效期): 用于指定本次预检请求的有效期(单位为秒)。

当浏览器检测到跨域请求时,会首先发起一个预检请求(OPTIONS 请求),以确认实际请求是否被允许。如果服务器允许跨域访问,将在实际请求中附带相应的头部信息。

以下是一个简单的 CORS 示例:

// 服务器端设置 CORS 头部
const express = require('express');
const app = express();

app.use((req, res, next) => {
   
    res.header('Access-Control-Allow-Origin', 'http://example.com');
    res.header('Access-Control-Allow-Methods', 'GET, POST, OPTIONS');
    res.header('Access-Control-Allow-Headers', 'Content-Type');
    res.header('Access-Control-Allow-Credentials', 'true');
    next();
});

app.get('/api/data', (req, res) => {
   
    res.json({
    message: 'Data from the server' });
});

app.listen(3000, () => {
   
    console.log('Server is running on port 3000');
});

在上述例子中,服务器设置了允许访问的来源、允许的请求方法、允许的请求头等信息。前端页面通过浏览器发起跨域请求时,如果满足了服务器的跨域规则,就能成功获取到服务器端的数据。

相关文章
|
18天前
|
JSON JavaScript 前端开发
js跨域实现
【10月更文挑战第31天】在实际开发中,需要根据具体的需求和项目情况选择合适的跨域解决方案。
18 1
|
15天前
|
开发框架 中间件 Java
如何处理跨域资源共享(CORS)的 OPTIONS 请求?
处理 CORS 的 OPTIONS 请求的关键是正确设置响应头,以告知浏览器是否允许跨域请求以及允许的具体条件。根据所使用的服务器端技术和框架,可以选择相应的方法来实现对 OPTIONS 请求的处理,从而确保跨域资源共享的正常进行。
|
15天前
|
JavaScript 前端开发 API
跨域资源共享(CORS)的工作原理是什么?
跨域资源共享(CORS)通过浏览器和服务器之间的这种交互机制,在保证安全性的前提下,实现了跨域资源的访问,使得不同源的网页能够合法地获取和共享服务器端的资源,为现代Web应用的开发提供了更大的灵活性和扩展性。
|
1月前
|
安全 前端开发 网络协议
[Http] 跨源资源共享(CORS)
[Http] 跨源资源共享(CORS)
|
2月前
|
安全
CORS 跨域资源共享的实现原理
CORS 跨域资源共享的实现原理
|
4月前
|
安全
CORS 跨域资源共享的实现原理
CORS 跨域资源共享的实现原理
|
3月前
|
安全 开发者 UED
|
4月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp的闲置物品共享平台附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的闲置物品共享平台附带文章源码部署视频讲解等
40 1
|
4月前
|
缓存 前端开发 Java
在Java项目中实现跨域资源共享(CORS)
在Java项目中实现跨域资源共享(CORS)
|
4月前
|
前端开发 JavaScript Java
使用Spring Boot实现跨域资源共享(CORS)
使用Spring Boot实现跨域资源共享(CORS)