【个人博客搭建】(19)Cors跨域配置

2024-05-29 03:28

本文主要是介绍【个人博客搭建】(19)Cors跨域配置,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

跨域,通常是指浏览器的同源策略限制所导致的一个问题。同源策略是一种安全特性,用于防止恶意站点从另一个站点读取敏感数据。在现代web开发中,尤其是采用前后端分离架构的应用,经常会遇到需要允许其他网站向自己的应用发出跨源请求的情况。.NET Core提供了多种方式来配置跨域资源共享(CORS),以解决这一问题。以下是关于跨域问题的相关介绍:

  1. 启用CORS的方法

    • 全局配置:通过在Startup类的ConfigureServices方法中添加CORS服务,并在Configure方法中应用这些服务来实现全局的跨域配置。
    • 特定终结点:可以将CORS策略应用于所有控制器终结点,或者针对特定的终结点进行配置,提供更细粒度的控制。
  2. 配置CORS的策略

    • 允许所有来源:通过配置策略以允许来自任何源的请求,这在某些情况下可以简化开发和测试过程。
    • 限制特定来源:出于安全考虑,通常会限制只有特定的源才能访问API,这样可以防止未授权的第三方访问敏感数据。
  3. 使用配置文件

    • 动态配置源:可以通过配置文件来管理允许跨域的源列表,这样在需要添加或修改允许跨域的源时,无需更改代码即可实现。
  4. 中间件的顺序

    • 正确放置CORS中间件:在管道中添加CORS中间件时,必须确保其位于正确的位置,例如,在使用路由和认证中间件之前应用CORS策略。
  5. 预检请求的处理

    • 处理OPTIONS请求:浏览器在发出非简单请求之前,会先发送一个预检请求。服务器需要正确处理这种请求,以通知浏览器允许的HTTP方法和头部字段。
  6. 代码与IIS配置

    • 两种方式实现:除了在代码中配置CORS之外,还可以通过IIS配置来实现跨域,这在某些部署场景下可能更为适用。

此外,在使用CORS时,还应注意以下几点:

  • 安全性考虑:虽然CORS提供了一种放宽同源策略的机制,但它本身并不是一种安全功能。因此,在配置CORS时,应仔细考虑哪些源应该被允许访问,以避免潜在的安全风险。
  • 缓存的影响:当使用响应缓存时,应在添加CORS中间件之前配置缓存,以确保CORS策略的正确应用。
  • 方法和头部字段:在配置CORS策略时,应根据实际需要允许适当的HTTP方法和头部字段,以满足应用程序的需求,同时不过度开放接口。

总的来说,.NET Core提供了灵活的配置选项来处理跨域问题,开发者可以根据应用的安全需求和架构特点选择合适的方法和策略。通过合理配置CORS,可以在保证安全的前提下,实现不同源之间的资源交互和数据共享。

1、json配置文件 

  /* Cors跨域配置 */"Cors": {"Enabled": true,//固定"Urls": ["http:localhost:5173","http:localhost:5174","http:localhost:8080"]}

2、Program.cs 入口文件:

//读取json
var corsEnabled = AppSettings.app(new string[] { "Cors", "Enabled" });//固定true
var corsUrlsList = AppSettings.app<string>("Cors", "Urls").ToArray();
//设置
builder.Services.AddCors(options =>
{options.AddPolicy("BlogCorsPolicy", opt => opt.WithOrigins(corsUrlsList)// 允许来自指定域名的请求.AllowAnyHeader()// 允许任何请求头.AllowAnyMethod()// 允许任何HTTP方法);
});

3、应用


app.UseCors("BlogCorsPolicy"); // 应用CORS策略

4、其他:

        4.1、具体针对不同的情况可以设置不同的策略方式

        ......

这篇关于【个人博客搭建】(19)Cors跨域配置的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1012512

相关文章

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

全面解析Golang 中的 Gorilla CORS 中间件正确用法

《全面解析Golang中的GorillaCORS中间件正确用法》Golang中使用gorilla/mux路由器配合rs/cors中间件库可以优雅地解决这个问题,然而,很多人刚开始使用时会遇到配... 目录如何让 golang 中的 Gorilla CORS 中间件正确工作一、基础依赖二、错误用法(很多人一开

Debian系和Redhat系防火墙配置方式

《Debian系和Redhat系防火墙配置方式》文章对比了Debian系UFW和Redhat系Firewalld防火墙的安装、启用禁用、端口管理、规则查看及注意事项,强调SSH端口需开放、规则持久化,... 目录Debian系UFW防火墙1. 安装2. 启用与禁用3. 基本命令4. 注意事项5. 示例配置R

Python极速搭建局域网文件共享服务器完整指南

《Python极速搭建局域网文件共享服务器完整指南》在办公室或家庭局域网中快速共享文件时,许多人会选择第三方工具或云存储服务,但这些方案往往存在隐私泄露风险或需要复杂配置,下面我们就来看看如何使用Py... 目录一、android基础版:HTTP文件共享的魔法命令1. 一行代码启动HTTP服务器2. 关键参

PyCharm中配置PyQt的实现步骤

《PyCharm中配置PyQt的实现步骤》PyCharm是JetBrains推出的一款强大的PythonIDE,结合PyQt可以进行pythion高效开发桌面GUI应用程序,本文就来介绍一下PyCha... 目录1. 安装China编程PyQt1.PyQt 核心组件2. 基础 PyQt 应用程序结构3. 使用 Q

Redis MCP 安装与配置指南

《RedisMCP安装与配置指南》本文将详细介绍如何安装和配置RedisMCP,包括快速启动、源码安装、Docker安装、以及相关的配置参数和环境变量设置,感兴趣的朋友一起看看吧... 目录一、Redis MCP 简介二、安www.chinasem.cn装 Redis MCP 服务2.1 快速启动(推荐)2.

Spring Boot配置和使用两个数据源的实现步骤

《SpringBoot配置和使用两个数据源的实现步骤》本文详解SpringBoot配置双数据源方法,包含配置文件设置、Bean创建、事务管理器配置及@Qualifier注解使用,强调主数据源标记、代... 目录Spring Boot配置和使用两个数据源技术背景实现步骤1. 配置数据源信息2. 创建数据源Be

Spring Boot Maven 插件如何构建可执行 JAR 的核心配置

《SpringBootMaven插件如何构建可执行JAR的核心配置》SpringBoot核心Maven插件,用于生成可执行JAR/WAR,内置服务器简化部署,支持热部署、多环境配置及依赖管理... 目录前言一、插件的核心功能与目标1.1 插件的定位1.2 插件的 Goals(目标)1.3 插件定位1.4 核

RabbitMQ消息总线方式刷新配置服务全过程

《RabbitMQ消息总线方式刷新配置服务全过程》SpringCloudBus通过消息总线与MQ实现微服务配置统一刷新,结合GitWebhooks自动触发更新,避免手动重启,提升效率与可靠性,适用于配... 目录前言介绍环境准备代码示例测试验证总结前言介绍在微服务架构中,为了更方便的向微服务实例广播消息,

nginx 负载均衡配置及如何解决重复登录问题

《nginx负载均衡配置及如何解决重复登录问题》文章详解Nginx源码安装与Docker部署,介绍四层/七层代理区别及负载均衡策略,通过ip_hash解决重复登录问题,对nginx负载均衡配置及如何... 目录一:源码安装:1.配置编译参数2.编译3.编译安装 二,四层代理和七层代理区别1.二者混合使用举例