【个人博客搭建】(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

相关文章

Nacos注册中心和配置中心的底层原理全面解读

《Nacos注册中心和配置中心的底层原理全面解读》:本文主要介绍Nacos注册中心和配置中心的底层原理的全面解读,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录临时实例和永久实例为什么 Nacos 要将服务实例分为临时实例和永久实例?1.x 版本和2.x版本的区别

如何搭建并配置HTTPD文件服务及访问权限控制

《如何搭建并配置HTTPD文件服务及访问权限控制》:本文主要介绍如何搭建并配置HTTPD文件服务及访问权限控制的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、安装HTTPD服务二、HTTPD服务目录结构三、配置修改四、服务启动五、基于用户访问权限控制六、

pytest+allure环境搭建+自动化实践过程

《pytest+allure环境搭建+自动化实践过程》:本文主要介绍pytest+allure环境搭建+自动化实践过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、pytest下载安装1.1、安装pytest1.2、检测是否安装成功二、allure下载安装2.

使用vscode搭建pywebview集成vue项目实践

《使用vscode搭建pywebview集成vue项目实践》:本文主要介绍使用vscode搭建pywebview集成vue项目实践,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录环境准备项目源码下载项目说明调试与生成可执行文件核心代码说明总结本节我们使用pythonpywebv

CentOS 7 YUM源配置错误的解决方法

《CentOS7YUM源配置错误的解决方法》在使用虚拟机安装CentOS7系统时,我们可能会遇到YUM源配置错误的问题,导致无法正常下载软件包,为了解决这个问题,我们可以替换YUM源... 目录一、备份原有的 YUM 源配置文件二、选择并配置新的 YUM 源三、清理旧的缓存并重建新的缓存四、验证 YUM 源

Windows 系统下 Nginx 的配置步骤详解

《Windows系统下Nginx的配置步骤详解》Nginx是一款功能强大的软件,在互联网领域有广泛应用,简单来说,它就像一个聪明的交通指挥员,能让网站运行得更高效、更稳定,:本文主要介绍W... 目录一、为什么要用 Nginx二、Windows 系统下 Nginx 的配置步骤1. 下载 Nginx2. 解压

VS配置好Qt环境之后但无法打开ui界面的问题解决

《VS配置好Qt环境之后但无法打开ui界面的问题解决》本文主要介绍了VS配置好Qt环境之后但无法打开ui界面的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 目UKeLvb录找到Qt安装目录中designer.UKeLvBexe的路径找到vs中的解决方案资源

windows系统上如何进行maven安装和配置方式

《windows系统上如何进行maven安装和配置方式》:本文主要介绍windows系统上如何进行maven安装和配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不... 目录1. Maven 简介2. maven的下载与安装2.1 下载 Maven2.2 Maven安装2.

Apache 高级配置实战之从连接保持到日志分析的完整指南

《Apache高级配置实战之从连接保持到日志分析的完整指南》本文带你从连接保持优化开始,一路走到访问控制和日志管理,最后用AWStats来分析网站数据,对Apache配置日志分析相关知识感兴趣的朋友... 目录Apache 高级配置实战:从连接保持到日志分析的完整指南前言 一、Apache 连接保持 - 性

MySQL 安装配置超完整教程

《MySQL安装配置超完整教程》MySQL是一款广泛使用的开源关系型数据库管理系统(RDBMS),由瑞典MySQLAB公司开发,目前属于Oracle公司旗下产品,:本文主要介绍MySQL安装配置... 目录一、mysql 简介二、下载 MySQL三、安装 MySQL四、配置环境变量五、配置 MySQL5.1