解决.Net Core跨域问题

Posted 2018clg

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了解决.Net Core跨域问题相关的知识,希望对你有一定的参考价值。

什么是跨域?
浏览器从一个域名的网页去请求另一个域名的资源时,域名、端口、协议任一不同,都是跨域
跨域的几种情况
 1、端口和协议的不同,只能通过后台来解决
 2、localhost和127.0.0.1虽然都指向本机,但也属于跨域

我们在同一个解决方案下,新建一个静态网站和一个.Net Core Mvc网站,此时在静态网站中的页面去访问Mvc网站中的接口就会出现跨域问题。

技术图片

这里Ajax访问接口回调始终会回到error中。

 

技术图片

 

浏览器中的Console会报错“Access-Control-Allow-Origin”

 

此时我们需要在Mvc网站的Startup.cs中做响应的配置

1.在Startup.cs中的ConfigureServices中粘贴以下代码:

 services.AddCors(options =>
            {
                options.AddPolicy("all", builder =>
                {
                    builder.AllowAnyOrigin() //允许任何来源的主机访问
                    .AllowAnyMethod()
                    .AllowAnyHeader()
                    .AllowCredentials();//指定处理cookie
                });
            });

 

 

2.在Startup.cs中的Configure中粘贴以下代码:

app.UseCors("all");

 

这里需要注意 “all” 可以用任意字符代替,但是ConfigureServices和ConfigureServices中的 “all” 字符要一样。

 

 

这时再来看下访问结果:

技术图片

 

以上是关于解决.Net Core跨域问题的主要内容,如果未能解决你的问题,请参考以下文章

.net core 3.1 webapi解决跨域问题 GET DELETE POST PUT等

Asp.NET Core:对服务的跨域请求(预检)返回代码 204 而不是 200

关于.Net Core 前后端分离跨域请求时 ajax并发请求导致部分无法通过验证解决办法。

uniapp跨域调用ASP.NET Core Web API

uniapp跨域调用ASP.NET Core Web API

uniapp跨域调用ASP.NET Core Web API