0

0

C#如何处理跨域问题 C# ASP.NET Core启用CORS的配置

幻夢星雲

幻夢星雲

发布时间:2025-11-24 06:47:31

|

949人浏览过

|

来源于php中文网

原创

在C# ASP.NET Core中处理跨域问题需启用CORS,通过在Program.cs中添加AddCors服务并定义策略,如指定允许的源、头、方法及凭据,再在UseRouting后调用UseCors应用策略,可全局或在控制器上使用EnableCors特性控制跨域访问,注意生产环境应避免AllowAnyOrigin,确保安全。

c#如何处理跨域问题 c# asp.net core启用cors的配置

在C# ASP.NET Core中处理跨域问题,主要通过启用CORS(Cross-Origin Resource Sharing)来实现。浏览器出于安全考虑,默认禁止前端应用向不同源的服务器发起请求,因此当你的前端(如Vue、React、Angular)与后端API部署在不同域名或端口时,就需要配置CORS。

什么是CORS

CORS是一种W3C标准,允许服务端声明哪些外部源可以访问其资源。ASP.NET Core提供了灵活的CORS策略配置方式,可以在程序启动时定义策略,并应用于特定控制器或全局接口。

启用CORS的步骤

以下是ASP.NET Core项目中启用CORS的标准流程:

1. 在 Program.cs 中添加CORS服务

Program.cs 文件中,在调用 builder.Services.AddControllers() 之后,使用 AddCors 方法添加CORS服务并定义策略:

var builder = WebApplication.CreateBuilder(args);

// 添加CORS服务 builder.Services.AddCors(options => { options.AddPolicy("AllowSpecificOrigin", policy => { policy.WithOrigins("https://www.php.cn/link/8e5687e2d6ab87e5da2f833f3e8986a4") // 允许的前端地址 .AllowAnyHeader() .AllowAnyMethod() .AllowCredentials(); // 如果需要发送凭据(如Cookie) }); });

builder.Services.AddControllers();

2. 使用CORS中间件

app 构建部分,调用 UseCors 启用中间件。注意顺序:必须在 UseRouting 之后,UseAuthorization 之前或之后(视需求),但在 UseEndpointsMapControllers 之前。

var app = builder.Build();

if (app.Environment.IsDevelopment()) { app.UseDeveloperExceptionPage(); }

app.UseRouting();

Mapify
Mapify

Mapify是由Xmind推出的AI思维导图生成工具,原名ChatMind

下载

// 使用CORS策略 app.UseCors("AllowSpecificOrigin");

app.UseAuthorization();

app.MapControllers();

app.Run();

可选:全局启用CORS

如果你希望所有控制器都默认支持跨域,可以直接在策略中设置,并在 UseCors 中指定策略名。也可以使用 AllowAnyOrigin(),但不推荐用于生产环境:

policy.AllowAnyOrigin() // 不安全,建议指定具体域名
      .AllowAnyHeader()
      .AllowAnyMethod();

在控制器或Action上启用CORS

如果不想全局启用,也可以只在特定控制器或方法上启用CORS。先定义一个命名策略或使用匿名策略,然后通过特性标注:

[EnableCors("AllowSpecificOrigin")]
[ApiController]
[Route("[controller]")]
public class WeatherController : ControllerBase
{
    [HttpGet]
    public IActionResult Get()
    {
        return Ok(new { message = "Hello from API" });
    }
}

或者关闭全局CORS,在某个Action上单独启用:

[DisableCors]
public IActionResult SomeAction() { ... }

[EnableCors("AllowSpecificOrigin")] public IActionResult PublicApi() { ... }

常见问题与注意事项

  • 确保 UseCors 调用在 UseRouting 之后,否则不会生效。
  • 若前端需要携带凭据(如Cookie、Authorization头),必须设置 AllowCredentials(),同时前端请求需设置 credentials: 'include',且不能使用 AllowAnyOrigin(),必须明确指定域名。
  • 生产环境中避免使用 AllowAnyOriginAllowAnyMethod,应严格限制来源和HTTP方法。
  • 多个策略可以定义,按名称选择使用。

基本上就这些。只要正确注册服务、配置策略、使用中间件,并注意执行顺序,C# ASP.NET Core就能顺利解决跨域请求问题。

相关专题

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

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

176

2024.05.11

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

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

212

2025.12.18

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

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

145

2023.12.20

cookie
cookie

Cookie 是一种在用户计算机上存储小型文本文件的技术,用于在用户与网站进行交互时收集和存储有关用户的信息。当用户访问一个网站时,网站会将一个包含特定信息的 Cookie 文件发送到用户的浏览器,浏览器会将该 Cookie 存储在用户的计算机上。之后,当用户再次访问该网站时,浏览器会向服务器发送 Cookie,服务器可以根据 Cookie 中的信息来识别用户、跟踪用户行为等。

6414

2023.06.30

document.cookie获取不到怎么解决
document.cookie获取不到怎么解决

document.cookie获取不到的解决办法:1、浏览器的隐私设置;2、Same-origin policy;3、HTTPOnly Cookie;4、JavaScript代码错误;5、Cookie不存在或过期等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

339

2023.11.23

阻止所有cookie什么意思
阻止所有cookie什么意思

阻止所有cookie意味着在浏览器中禁止接受和存储网站发送的cookie。阻止所有cookie可能会影响许多网站的使用体验,因为许多网站使用cookie来提供个性化服务、存储用户信息或跟踪用户行为。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

404

2024.02.23

cookie与session的区别
cookie与session的区别

本专题整合了cookie与session的区别和使用方法等相关内容,阅读专题下面的文章了解更详细的内容。

88

2025.08.19

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1007

2023.10.19

c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

3

2026.01.09

热门下载

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

精品课程

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

共94课时 | 6.3万人学习

C 教程
C 教程

共75课时 | 3.9万人学习

C++教程
C++教程

共115课时 | 11.7万人学习

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

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