”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 解决 CORS 问题的方法

解决 CORS 问题的方法

发布于2024-11-07
浏览:978

Ways to resolve CORS issues

要解决 CORS 问题,您需要在 Web 服务器(如 Apache 或 Nginx)、后端(如 Django、Go 或 Node.js)中添加适当的标头,或在前端框架(如 React 或 Next.js)中。以下是每个平台的步骤:

1. 网络服务器

阿帕奇

您可以在 Apache 的配置文件(例如 .htaccess、httpd.conf 或 apache2.conf)中或在特定虚拟主机配置中配置 CORS 标头。

添加以下行以启用 CORS:


    Header set Access-Control-Allow-Origin "*"
    Header set Access-Control-Allow-Methods "GET, POST, PUT, DELETE, OPTIONS"
    Header set Access-Control-Allow-Headers "Content-Type, Authorization"
  • 对特定域应用 CORS:
  Header set Access-Control-Allow-Origin "https://example.com"
  • 如果需要凭据:
  Header set Access-Control-Allow-Credentials "true"

确保 mod_headers 模块已启用。如果没有,请使用以下命令启用它:

sudo a2enmod headers
sudo systemctl restart apache2

Nginx

在 Nginx 中,您可以在 nginx.conf 或特定服务器块中配置 CORS 标头。

添加以下行:

server {
    location / {
        add_header Access-Control-Allow-Origin "*";
        add_header Access-Control-Allow-Methods "GET, POST, PUT, DELETE, OPTIONS";
        add_header Access-Control-Allow-Headers "Content-Type, Authorization";
    }

    # Optional: Add for handling preflight OPTIONS requests
    if ($request_method = OPTIONS) {
        add_header Access-Control-Allow-Origin "*";
        add_header Access-Control-Allow-Methods "GET, POST, OPTIONS, PUT, DELETE";
        add_header Access-Control-Allow-Headers "Authorization, Content-Type";
        return 204;
    }
}
  • 如果需要凭据:
  add_header Access-Control-Allow-Credentials "true";

然后重启Nginx:

sudo systemctl restart nginx

2. 后端框架

姜戈

在 Django 中,您可以使用 django-cors-headers 包添加 CORS 标头。

  1. 安装包:
   pip install django-cors-headers
  1. 将“corsheaders”添加到 settings.py 中的 INSTALLED_APPS 中:
   INSTALLED_APPS = [
       ...
       'corsheaders',
   ]
  1. 将 CORS 中间件添加到您的中间件中:
   MIDDLEWARE = [
       'corsheaders.middleware.CorsMiddleware',
       'django.middleware.common.CommonMiddleware',
       ...
   ]
  1. 在settings.py中设置允许的来源:
   CORS_ALLOWED_ORIGINS = [
       "https://example.com",
   ]
  • 允许所有来源:
  CORS_ALLOW_ALL_ORIGINS = True
  • 如果需要凭据:
  CORS_ALLOW_CREDENTIALS = True
  • 允许特定标头或方法:
  CORS_ALLOW_HEADERS = ['Authorization', 'Content-Type']
  CORS_ALLOW_METHODS = ['GET', 'POST', 'PUT', 'DELETE', 'OPTIONS']

Go(Go 语言)

在 Go 中,您可以在 HTTP 处理程序中手动处理 CORS 或使用像 rs/cors 这样的中间件。

使用 rs/cors 中间件:

  1. 安装包:
   go get github.com/rs/cors
  1. 在您的应用程序中使用它:
   package main

   import (
       "net/http"
       "github.com/rs/cors"
   )

   func main() {
       mux := http.NewServeMux()

       // Example handler
       mux.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
           w.Write([]byte("Hello, World!"))
       })

       // CORS middleware
       handler := cors.New(cors.Options{
           AllowedOrigins:   []string{"https://example.com"}, // Or use * for all
           AllowedMethods:   []string{"GET", "POST", "PUT", "DELETE", "OPTIONS"},
           AllowedHeaders:   []string{"Authorization", "Content-Type"},
           AllowCredentials: true,
       }).Handler(mux)

       http.ListenAndServe(":8080", handler)
   }

Node.js (Express)

在Express(Node.js)中,可以使用cors中间件。

  1. 安装cors包:
   npm install cors
  1. 在 Express 应用程序中添加中间件:
   const express = require('express');
   const cors = require('cors');
   const app = express();

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

   // To allow specific origins
   app.use(cors({
       origin: 'https://example.com',
       methods: ['GET', 'POST', 'PUT', 'DELETE'],
       allowedHeaders: ['Authorization', 'Content-Type'],
       credentials: true
   }));

   // Example route
   app.get('/', (req, res) => {
       res.send('Hello World');
   });

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

3. 前端框架

反应

在React中,CORS由后端处理,但在开发过程中,您可以代理API请求以避免CORS问题。

  1. 向package.json添加代理:
   {
     "proxy": "http://localhost:5000"
   }

这将在开发期间将请求代理到在端口 5000 上运行的后端服务器。

对于生产,后端应该处理 CORS。如果需要,请使用 http-proxy-middleware 等工具进行更多控制。

Next.js

在Next.js中,您可以在API路由中配置CORS。

  1. 为API路由创建自定义中间件:
   export default function handler(req, res) {
       res.setHeader('Access-Control-Allow-Origin', '*'); // Allow all origins
       res.setHeader('Access-Control-Allow-Methods', 'GET, POST, PUT, DELETE, OPTIONS');
       res.setHeader('Access-Control-Allow-Headers', 'Authorization, Content-Type');

       if (req.method === 'OPTIONS') {
           // Handle preflight request
           res.status(200).end();
           return;
       }

       // Handle the actual request
       res.status(200).json({ message: 'Hello from Next.js' });
   }
  1. 在next.config.js中,您还可以修改响应头:
   module.exports = {
       async headers() {
           return [
               {
                   source: '/(.*)', // Apply to all routes
                   headers: [
                       {
                           key: 'Access-Control-Allow-Origin',
                           value: '*', // Allow all origins
                       },
                       {
                           key: 'Access-Control-Allow-Methods',
                           value: 'GET, POST, PUT, DELETE, OPTIONS',
                       },
                       {
                           key: 'Access-Control-Allow-Headers',
                           value: 'Authorization, Content-Type',
                       },
                   ],
               },
           ];
       },
   };

在哪里添加标头的摘要:

  • Web 服务器(Apache、Nginx):在服务器配置文件中配置(例如 .htaccess、nginx.conf)。
  • 后端框架
    • Django:使用 django-cors-headers。
    • Go:手动添加标头或使用像 rs/cors 这样的中间件。
    • Node.js (Express):使用 cors 中间件。
  • 前端:在开发中,使用代理设置(如 React 的代理或 Next.js 自定义标头)来避免 CORS 问题,但始终在生产中的后端处理 CORS。
版本声明 本文转载于:https://dev.to/tikam02/ways-to-resolve-cors-issues-15on?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 解锁 JavaScript 的隐藏宝石:未充分利用的功能可提高代码质量和性能
    解锁 JavaScript 的隐藏宝石:未充分利用的功能可提高代码质量和性能
    In the ever-evolving landscape of web development, JavaScript remains a cornerstone technology powering countless large-scale web applications. While...
    编程 发布于2024-11-07
  • 为什么通过非常量指针修改“const”变量看起来有效,但实际上并没有改变它的值?
    为什么通过非常量指针修改“const”变量看起来有效,但实际上并没有改变它的值?
    通过非常量指针修改 const在 C 中,const 变量一旦初始化就无法修改。但是,在某些情况下,const 变量可能会被更改。考虑以下代码:const int e = 2; int* w = (int*)&e; // (1) *w = 5; ...
    编程 发布于2024-11-07
  • Android - 将 .aab 文件上传到 Play 商店时出错
    Android - 将 .aab 文件上传到 Play 商店时出错
    如果您遇到此错误,请按照以下步骤操作以确保与您的包名称和签名密钥保持一致: 确保 app.json 文件中的包名称与您第一次上传 .aab 文件时使用的包名称匹配。 "android": { "permissions":["CAMERA","READ_EXTERNAL_STORAGE...
    编程 发布于2024-11-07
  • 如何使用 PHP 将 HTML 转换为 PDF
    如何使用 PHP 将 HTML 转换为 PDF
    (适用于 Windows 的指南。不适用于 Mac 或 Linux) (图片来源) 在 PHP 中将 HTML 转换为 PDF 的方法不止一种。您可以使用Dompdf或Mpdf;但是,这两个库的执行方式有所不同。 注意:本文中并未包含所有解决方案。 要使用这两个库,您将需要 Composer。 ...
    编程 发布于2024-11-07
  • C++ 会拥抱垃圾收集吗?
    C++ 会拥抱垃圾收集吗?
    C 中的垃圾收集:实现和共识的问题虽然有人建议 C 最终会包含垃圾收集器,但它仍然是争论和持续发展的主题。要理解其中的原因,我们必须深入研究迄今为止阻碍其纳入的挑战和考虑因素。实现复杂性向 C 添加隐式垃圾收集是一个非-琐碎的任务。该语言的低级性质和对指针的广泛支持带来了重大的技术障碍。实施问题的范...
    编程 发布于2024-11-07
  • 如何有条件地删除 MySQL 中的列?
    如何有条件地删除 MySQL 中的列?
    使用 MySQL ALTER 进行条件列删除MySQL 中的 ALTER 命令提供了一种从表中删除列的简单方法。但是,当指定列不存在时,其传统语法 (ALTER TABLE table_name DROP COLUMN column_name) 会引发错误。对于 MySQL 版本 4.0.18,没有...
    编程 发布于2024-11-07
  • 你应该了解的现代 CSS 样式 4
    你应该了解的现代 CSS 样式 4
    TL;DR: 本博客使用代码示例来探索 Web 开发的五种最佳 CSS 样式和功能:容器查询、子网格、伪类、逻辑属性和实验室颜色空间。它们增强响应能力、简化布局并提高设计一致性。 层叠样式表 (CSS) 是一种众所周知的用于设计网页样式的语言。使用 CSS,您可以通过添加空格来自定义 HTML 元素...
    编程 发布于2024-11-07
  • 箭头函数或父作用域何时定义函数的参数?
    箭头函数或父作用域何时定义函数的参数?
    ES6 箭头函数中的参数:官方说明在 ES6 箭头函数中,arguments 关键字的行为一直是争论的话题。一些浏览器和平台(例如 Chrome、Firefox 和 Node)偏离了最初的 TC39 建议,引发了对该规范正确解释的质疑。根据官方 ES6 规范,箭头函数没有其自身的定义。自己的参数在其...
    编程 发布于2024-11-07
  • 根据您提供的内容,以下是一些采用问题格式的潜在文章标题:

* 加载数据本地内文件访问被拒绝:如何排除和修复错误? 
* 为什么要加载数据LOCA
    根据您提供的内容,以下是一些采用问题格式的潜在文章标题: * 加载数据本地内文件访问被拒绝:如何排除和修复错误? * 为什么要加载数据LOCA
    LOAD DATA LOCAL INFILE 访问被错误拒绝:不允许使用的命令当利用 MySQL 的 LOAD DATA INFILE 执行 PHP 脚本时,它可能会遇到错误“用户访问被拒绝...(使用密码:是)”。常见的解决方法是切换到 LOAD DATA LOCAL INFILE,尽管这可能会导...
    编程 发布于2024-11-07
  • 如何在 Python 中检查文本文件是否为空?
    如何在 Python 中检查文本文件是否为空?
    确定文本文件是否为空在编程领域,通常需要确定特定文件是否包含任何数据或无效。本文深入探讨了这样一个问题:“我们如何确定文本文件是否为空?”Python 作为一种多功能编程语言,为这个问题提供了一个简单的解决方案。通过利用 os.stat() 函数,我们可以检索有关文件的属性数组,包括其大小。查询答案...
    编程 发布于2024-11-07
  • 在 MySQL 中存储 IPv6 地址的最佳方式是什么?
    在 MySQL 中存储 IPv6 地址的最佳方式是什么?
    在 MySQL 中存储 IPv6 地址:DECIMAL(39,0) 与 VARBINARY(16)当面临存储 IPv6 的挑战时对于 MySQL 中的地址,开发人员通常会考虑两个选项:DECIMAL(39,0) 和 2*BIGINT。虽然两者各有优点,但出现了一种较以前的方法更具优势的新解决方案。D...
    编程 发布于2024-11-07
  • ES6 类是 JavaScript 原型模式的语法糖吗?
    ES6 类是 JavaScript 原型模式的语法糖吗?
    ES6 类只是 Javascript 中原型模式的语法糖吗?不,ES6 类不仅仅是 Javascript 原型模式的语法糖原型模式。 虽然它们确实有一些相似之处,但也存在一些关键差异,这些差异使 ES6 类成为创建和使用对象的更强大、更方便的方式。以下是关键差异的细分ES6 类和原型模式之间:ES6...
    编程 发布于2024-11-07
  • #daysofMiva 挑战赛的第一天。
    #daysofMiva 挑战赛的第一天。
    100 天挑战的第一天 日期: 8/21/2024 目标: 学习和理解 JavaScript 中的变量、逻辑运算和数据类型,使用 JavaScript 解决数学问题,并开始学习事件监听器和条件语句。 1. JavaScript变量介绍 今天,我通过学习变量开始了 JavaScript...
    编程 发布于2024-11-07
  • 如何将 PHP 生成的值安全地集成到 JavaScript 代码中?
    如何将 PHP 生成的值安全地集成到 JavaScript 代码中?
    将 PHP 生成的值合并到页面上的 JavaScript 中尝试将 PHP 生成的值嵌入到 JavaScript 代码中时,您可能会遇到类似于给定示例中的错误。要解决此问题,请考虑以下方法:<?php $htmlString = 'testing'; ?> <html> ...
    编程 发布于2024-11-07
  • 了解异步 JavaScript
    了解异步 JavaScript
    JavaScript 是一种单线程语言,这意味着它一次只能做一件事。然而,Web 应用程序通常需要执行从服务器获取数据等任务,这可能需要一些时间。如果 JavaScript 必须等待每个任务完成才能继续,那么您的 Web 应用程序将会变得缓慢且无响应。这就是异步(async)JavaScript发挥...
    编程 发布于2024-11-07

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3