.NET Core Web API如何处理跨域(CORS)问题

月夜之吻
发布: 2025-11-05 18:35:02
原创
383人浏览过
答案:.NET Core通过AddCors注册策略并UseCors启用中间件处理跨域,支持默认、命名策略及特性粒度控制,开发环境可宽松配置,生产环境需限制权限以保障安全。

.net core web api如何处理跨域(cors)问题

.NET Core Web API 处理跨域(CORS)问题非常常见,尤其是在前端应用(如 Vue、React、Angular)与后端 API 分离部署时。浏览器出于安全考虑,默认禁止跨域请求,因此需要在服务端显式配置 CORS 策略。

启用 CORS 的基本步骤

在 .NET Core 中,处理 CORS 需要两个关键步骤:注册 CORS 服务和使用中间件。

Program.cs(.NET 6 及以上版本)中添加以下代码:

var builder = WebApplication.CreateBuilder(args);

// 添加 CORS 服务

builder.Services.AddCors(options =>

{

   options.AddDefaultPolicy(policy =>

   {

      policy.WithOrigins("https://your-frontend.com") // 允许的前端域名

          .AllowAnyHeader()

奇域
奇域

奇域是一个专注于中式美学的国风AI绘画创作平台

奇域 30
查看详情 奇域

          .AllowAnyMethod();

   });

});

// 注册其他服务...

var app = builder.Build();

// 启用 CORS 中间件

app.UseCors();

配置不同的 CORS 策略

你可以定义多个命名策略,适用于不同场景。

builder.Services.AddCors(options =>

{

   options.AddPolicy("AllowLocalFrontend", policy =>

   {

      policy.WithOrigins("http://localhost:3000")

          .AllowAnyHeader()

          .AllowAnyMethod();

   });

   options.AddPolicy("ProductionFrontend", policy =>

   {

      policy.WithOrigins("https://example.com")

          .WithHeaders("Authorization", "Content-Type")

          .WithMethods("GET", "POST");

   });

});

使用时通过名称指定:

app.UseCors("AllowLocalFrontend");

允许任意跨域请求(仅开发环境

开发阶段为了方便调试,可以临时允许所有跨域请求:

policy.AllowAnyOrigin()

    .AllowAnyHeader()

    .AllowAnyMethod();

注意:生产环境中避免使用 AllowAnyOriginAllowAnyMethod,存在安全风险。

控制器或方法级别启用 CORS

如果只想对特定控制器或 Action 启用 CORS,可以在类或方法上加特性:

[EnableCors("AllowLocalFrontend")]

public class WeatherController : ControllerBase

或者关闭某个方法的 CORS:

[DisableCors]

[HttpGet("no-cors")]

public IActionResult NoCors() => Ok();

基本上就这些。只要正确配置策略并启用中间件,.NET Core 就能顺利处理跨域请求。关键是根据环境选择合适的策略粒度,开发时可宽松,上线前务必收紧权限。

以上就是.NET Core Web API如何处理跨域(CORS)问题的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

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