当前位置: 首页 > article >正文

介绍 HTTP 请求如何实现跨域

以下是关于 HTTP 请求如何实现跨域的详细介绍:

一、什么是跨域

跨域是指一个域下的文档或脚本试图去请求另一个域下的资源,这是由于浏览器的同源策略所导致的。同源策略是浏览器的一个安全机制,它要求协议、域名和端口都相同,否则会被认为是跨域请求。例如,http://example.comhttps://example.com 发送请求,或者 http://example.comhttp://api.example.com 发送请求,都属于跨域请求。

二、实现跨域的方法

1. CORS(跨域资源共享)

CORS 是一种现代的跨域解决方案,它允许服务器声明哪些源可以访问该资源。在服务器端,通过设置响应头来实现。

服务器端设置示例(以 Node.js 和 Express 为例):

const express = require('express');
const app = express();

app.use((req, res, next) => {
    // 允许所有源进行跨域访问
    res.setHeader('Access-Control-Allow-Origin', '*'); 
    // 允许的请求方法
    res.setHeader('Access-Control-Allow-Methods', 'GET, POST, PUT, DELETE'); 
    // 允许的请求头
    res.setHeader('Access-Control-Allow-Headers', 'Content-Type, Authorization'); 
    next();
});

app.get('/data', (req, res) => {
    res.send('This is some data');
});

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

解释:

  • res.setHeader('Access-Control-Allow-Origin', '*')* 表示允许任何源进行跨域访问,也可以指定具体的源,如 http://example.com
  • res.setHeader('Access-Control-Allow-Methods', 'GET, POST, PUT, DELETE'):定义允许的 HTTP 请求方法。
  • res.setHeader('Access-Control-Allow-Headers', 'Content-Type, Authorization'):定义允许的请求头。
2. JSONP(JSON with Padding)

JSONP 是一种比较古老的跨域解决方案,它利用 <script> 标签不受同源策略限制的特点。它需要服务器端的配合,服务器端将数据包装在一个函数调用中返回。

客户端代码示例:

<script>
    function handleData(data) {
        console.log(data);
    }
</script>
<script src="http://api.example.com/data?callback=handleData"></script>

服务器端代码示例(以 Node.js 为例):

const http = require('http');

http.createServer((req, res) => {
    const callback = req.url.split('?')[1].split('=')[1];
    const data = { message: 'Hello from server' };
    res.writeHead(200, {'Content-Type': 'application/javascript'});
    // 将数据包装在回调函数中返回
    res.end(`${callback}(${JSON.stringify(data)})`); 
}).listen(3000);

解释:

  • 客户端定义一个 handleData 函数。
  • 服务器端接收 callback 参数,将数据作为参数传递给该函数,并将函数调用作为响应返回。
3. 代理服务器

使用代理服务器可以绕过同源策略,因为客户端请求的是同域的代理服务器,然后代理服务器去请求另一个域的资源。

客户端代码示例(以 jQuery 为例):

<script src="https://code.jquery.com/jquery-3.6.0.min.js"></script>
<script>
    $.ajax({
        url: '/proxy',
        type: 'GET',
        success: function(data) {
            console.log(data);
        }
    });
</script>

服务器端代码示例(以 Node.js 和 Express 为例):

const express = require('express');
const request = require('request');
const app = express();

app.get('/proxy', (req, res) => {
    request('http://api.example.com/data', (error, response, body) => {
        if (!error && response.statusCode == 200) {
            res.send(body);
        }
    });
});

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

解释:

  • 客户端向 /proxy 发送请求,这是同域的。
  • 服务器端的 /proxy 路由接收到请求后,向真正的目标地址 http://api.example.com/data 发送请求,并将结果返回给客户端。
4. 反向代理(以 Nginx 为例)

在服务器端配置反向代理,将跨域请求转发到目标服务器。

Nginx 配置示例:

server {
    listen 80;
    server_name example.com;

    location /api/ {
        proxy_pass http://api.example.com/;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
    }
}

解释:

  • 当客户端请求 http://example.com/api/ 时,Nginx 会将请求转发到 http://api.example.com/,对于客户端来说,请求的是同域的资源,从而避免了跨域问题。

三、总结

  • CORS 是目前最常用的跨域解决方案,它提供了更灵活和安全的跨域访问控制,适合现代的 Web 开发。
  • JSONP 有一定的局限性,仅适用于 GET 请求,且存在安全风险。
  • 代理服务器和反向代理是通过服务器端转发请求,在某些场景下比较实用,但会增加服务器的负担。根据不同的需求和场景,可以选择不同的跨域解决方案。

http://www.kler.cn/a/512228.html

相关文章:

  • 光谱相机如何还原色彩
  • Scade 表达式 - 迭代器
  • 项目开发实践——基于SpringBoot+Vue3实现的在线考试系统(七)
  • Mysql 主从复制原理及其工作过程,配置一主两从实验
  • AIGC视频生成模型:Meta的Emu Video模型
  • 将IDLE里面python环境pyqt5配置的vscode
  • Oracle之RMAN备份异机恢复(单机到单机)
  • doris 2.1 Queries Acceleration-Hints 学习笔记
  • 头歌实训作业 算法设计与分析-贪心算法(第1关:部分背包问题)
  • 群晖Cloud Sync如何实现一键同步备份让数据更安全高效
  • 使用HTML5 Canvas 实现呼吸粒子球动画效果的原理
  • 软考,沟通管理
  • (开源)基于Django+Yolov8+Tensorflow的智能鸟类识别平台
  • Rust语言的正则表达式
  • 华为OD机试E卷 --日志首次上报最多积分 --24年OD统一考试(Java JS Python C C++)
  • 【0x0052】HCI_Write_Extended_Inquiry_Response命令详解
  • 基于SSM实现的乡村振兴文化平台系统功能实现八
  • LARGE LANGUAGE MODELS ARE HUMAN-LEVEL PROMPT ENGINEERS
  • 《Linux服务与安全管理》| 邮件服务器安装和配置
  • antd + VUE循环form-item的校验 循环校验(多层循环)
  • 二十六、资源限制-ResourceQuota
  • 无人机飞手考证难度增加,实操、地面站教学技术详解
  • 论文阅读笔记:AI+RPA
  • 第2章:Python TDD构建Dollar类基础
  • leetcode hot 100 -搜索二维矩阵
  • 微服务学习-Seata 解决分布式事务