0

0

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

月夜之吻

月夜之吻

发布时间:2025-11-05 18:35:02

|

418人浏览过

|

来源于php中文网

原创

答案:.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
谱乐AI

谱乐AI,集成 Suno、Udio 等顶尖AI音乐模型的一站式AI音乐生成平台。

下载

          .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 就能顺利处理跨域请求。关键是根据环境选择合适的策略粒度,开发时可宽松,上线前务必收紧权限。

相关专题

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

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

175

2024.05.11

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

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

146

2025.12.18

class在c语言中的意思
class在c语言中的意思

在C语言中,"class" 是一个关键字,用于定义一个类。想了解更多class的相关内容,可以阅读本专题下面的文章。

454

2024.01.03

python中class的含义
python中class的含义

本专题整合了python中class的相关内容,阅读专题下面的文章了解更多详细内容。

6

2025.12.06

http500解决方法
http500解决方法

http500解决方法有检查服务器日志、检查代码错误、检查服务器配置、检查文件和目录权限、检查资源不足、更新软件版本、重启服务器或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

249

2023.11.09

http请求415错误怎么解决
http请求415错误怎么解决

解决方法:1、检查请求头中的Content-Type;2、检查请求体中的数据格式;3、使用适当的编码格式;4、使用适当的请求方法;5、检查服务器端的支持情况。更多http请求415错误怎么解决的相关内容,可以阅读下面的文章。

380

2023.11.14

HTTP 503错误解决方法
HTTP 503错误解决方法

HTTP 503错误表示服务器暂时无法处理请求。想了解更多http错误代码的相关内容,可以阅读本专题下面的文章。

852

2024.03.12

http与https有哪些区别
http与https有哪些区别

http与https的区别:1、协议安全性;2、连接方式;3、证书管理;4、连接状态;5、端口号;6、资源消耗;7、兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1552

2024.08.16

虚拟号码教程汇总
虚拟号码教程汇总

本专题整合了虚拟号码接收验证码相关教程,阅读下面的文章了解更多详细操作。

25

2025.12.25

热门下载

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

精品课程

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

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