0

0

解决JavaScript跨域请求text/html类型API的CORB问题

DDD

DDD

发布时间:2025-09-13 22:24:01

|

411人浏览过

|

来源于php中文网

原创

解决javascript跨域请求text/html类型api的corb问题

本文旨在帮助开发者解决在使用JavaScript进行跨域请求时,由于目标网站返回的Content-Type为text/html而引发的CORB(Cross-Origin Read Blocking)问题。我们将深入探讨CORB的原理,并提供一种有效的解决方案,即通过服务器端代理来绕过浏览器的跨域限制,从而成功获取API的响应数据。

跨域资源共享(CORS)与跨域读取阻止(CORB)

在Web开发中,由于浏览器的同源策略限制,JavaScript通常无法直接从与当前页面不同源的服务器请求资源。CORS(Cross-Origin Resource Sharing)是一种机制,允许服务器声明哪些来源(域、协议和端口)有权访问其资源。服务器通过设置Access-Control-Allow-Origin响应头来控制跨域访问。

然而,即使服务器没有明确禁止跨域访问,浏览器也可能出于安全考虑,阻止某些类型的跨域响应。这就是CORB(Cross-Origin Read Blocking)的作用。CORB是一种安全机制,旨在防止恶意网站读取敏感的跨域数据。它主要针对text/html、text/plain和application/xml等MIME类型,因为这些类型的数据可能包含敏感信息,例如HTML片段或XML数据。

问题分析:为何text/html会导致CORB?

当浏览器检测到跨域请求的响应类型为text/html,并且服务器没有正确设置CORS头时,CORB会阻止JavaScript读取响应内容。这是因为浏览器认为直接将HTML内容暴露给JavaScript可能存在安全风险,例如XSS(Cross-Site Scripting)攻击。

立即学习Java免费学习笔记(深入)”;

在您提供的案例中,尽管使用了dataType: "jsonp"和设置了Access-Control-Allow-Origin': '*',但问题仍然存在。这是因为:

  1. Access-Control-Allow-Origin 是服务器响应头,而非客户端请求头。客户端设置此header没有意义。
  2. dataType: "jsonp" 期望服务器返回 JSONP 格式的数据。 JSONP 是一种利用

解决方案:服务器端代理

由于浏览器端的限制,直接使用JavaScript跨域请求text/html类型的API通常不可行。最可靠的解决方案是在服务器端创建一个代理。

XPaper Ai
XPaper Ai

AI撰写论文、开题报告生成、AI论文生成器尽在XPaper Ai论文写作辅助指导平台

下载

原理:

  1. 您的JavaScript代码向您自己的服务器发送请求。
  2. 您的服务器接收到请求后,使用服务器端代码(例如Node.js、Python、Java等)向目标API (https://pubmed.ncbi.nlm.nih.gov/?term=hello) 发送请求。
  3. 您的服务器接收到目标API的响应后,可以根据需要对数据进行处理(例如,提取所需信息),然后将处理后的数据返回给您的JavaScript代码。

示例 (Node.js):

const express = require('express');
const axios = require('axios');
const cors = require('cors'); // Import the cors middleware

const app = express();
const port = 3000;

// Enable CORS for all origins
app.use(cors());

app.get('/api/pubmed', async (req, res) => {
  try {
    const response = await axios.get('https://pubmed.ncbi.nlm.nih.gov/?term=hello');
    // You can process the response data here if needed
    res.send(response.data);
  } catch (error) {
    console.error(error);
    res.status(500).send('An error occurred');
  }
});

app.listen(port, () => {
  console.log(`Proxy server listening at http://localhost:${port}`);
});

前端JavaScript代码:



注意事项:

  • 安全性: 请确保您的服务器端代理采取了必要的安全措施,例如输入验证和输出编码,以防止安全漏洞。
  • CORS配置: 在服务器端,您需要配置CORS,允许您的前端应用程序访问代理API。在上面的Node.js示例中,使用了cors中间件来允许所有来源的访问。在生产环境中,您应该限制允许的来源。
  • 数据处理: 您可能需要对从目标API获取的数据进行处理,例如提取所需信息或将其转换为更易于使用的格式。
  • 错误处理: 完善的错误处理机制至关重要。确保您的服务器端代码能够处理各种错误情况,例如网络错误、API错误等。
  • 性能: 如果您需要处理大量的请求,请考虑使用缓存机制来提高性能。

总结:

通过服务器端代理,您可以绕过浏览器的跨域限制,成功获取text/html类型API的响应数据。这种方法不仅解决了CORB问题,还提供了更大的灵活性和控制权,您可以根据需要对数据进行处理和转换。始终牢记安全性,并采取适当的措施来保护您的应用程序免受潜在的安全风险。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
什么是中间件
什么是中间件

中间件是一种软件组件,充当不兼容组件之间的桥梁,提供额外服务,例如集成异构系统、提供常用服务、提高应用程序性能,以及简化应用程序开发。想了解更多中间件的相关内容,可以阅读本专题下面的文章。

178

2024.05.11

Golang 中间件开发与微服务架构
Golang 中间件开发与微服务架构

本专题系统讲解 Golang 在微服务架构中的中间件开发,包括日志处理、限流与熔断、认证与授权、服务监控、API 网关设计等常见中间件功能的实现。通过实战项目,帮助开发者理解如何使用 Go 编写高效、可扩展的中间件组件,并在微服务环境中进行灵活部署与管理。

215

2025.12.18

resource是什么文件
resource是什么文件

Resource文件是一种特殊类型的文件,它通常用于存储应用程序或操作系统中的各种资源信息。它们在应用程序开发中起着关键作用,并在跨平台开发和国际化方面提供支持。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

156

2023.12.20

pdf怎么转换成xml格式
pdf怎么转换成xml格式

将 pdf 转换为 xml 的方法:1. 使用在线转换器;2. 使用桌面软件(如 adobe acrobat、itext);3. 使用命令行工具(如 pdftoxml)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1900

2024.04.01

xml怎么变成word
xml怎么变成word

步骤:1. 导入 xml 文件;2. 选择 xml 结构;3. 映射 xml 元素到 word 元素;4. 生成 word 文档。提示:确保 xml 文件结构良好,并预览 word 文档以验证转换是否成功。想了解更多xml的相关内容,可以阅读本专题下面的文章。

2091

2024.08.01

xml是什么格式的文件
xml是什么格式的文件

xml是一种纯文本格式的文件。xml指的是可扩展标记语言,标准通用标记语言的子集,是一种用于标记电子文件使其具有结构性的标记语言。想了解更多相关的内容,可阅读本专题下面的相关文章。

1064

2024.11.28

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

514

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

244

2023.07.28

俄罗斯Yandex引擎入口
俄罗斯Yandex引擎入口

2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

158

2026.01.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 4.2万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 2.5万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号