广告
返回顶部
首页 > 资讯 > 精选 >ASP.NET CORE如何实现跨域
  • 153
分享到

ASP.NET CORE如何实现跨域

2023-06-29 11:06:18 153人浏览 安东尼
摘要

本篇内容主要讲解“asp.net CORE如何实现跨域”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“ASP.net CORE如何实现跨域”吧!一、后台api接口用.net c

本篇内容主要讲解“asp.net CORE如何实现跨域”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“ASP.net CORE如何实现跨域”吧!

一、后台api接口

.net core创建一个WEB API项目负责给前端界面提供数据。

二、前端界面

建立两个mvc项目,模拟不同的ip,在view里面添加按钮调用WEB API提供的接口进行测试跨域。view视图页代码如下:

@{    Layout = null;}<!DOCTYPE html><html><head>    <meta name="viewport" content="width=device-width" />    <title>跨域测试1</title>    <script src="~/Scripts/Jquery-1.10.2.js"></script>    <script>        function btnGet() {            $.ajax({                url: 'https://localhost:44355/api/values',                type: "Get",                dataType: "JSON",                success: function (data) {                    alert("成功");                },                error: function (data) {                    alert("失败");                }            });        }    </script></head><body>    <div>         <input type="button" id="btn" value="测试跨域" onclick="btnGet()" />    </div></body></html>

三、测试

1、不设置允许跨域

首先,先不设置.Net Core允许跨域,查看调用效果:

点击测试跨域1按钮:

ASP.NET CORE如何实现跨域

F12进入Debug模式查看失败原因:

ASP.NET CORE如何实现跨域

从这里可以看出来是因为产生了跨域问题,所以会失败。

点击测试跨域2的效果和此效果一致。

2、设置允许所有来源跨域

2.1、在StartUp类的ConfigureServices方法中添加如下代码:
// 配置跨域处理,允许所有来源services.AddCors(options =>options.AddPolicy("cors",p => p.AllowAnyOrigin().AllowAnyHeader().AllowAnyMethod().AllowCredentials()));
2.2、修改Configure方法
// 允许所有跨域,cors是在ConfigureServices方法中配置的跨域策略名称app.UseCors("cors");
2.3、测试

ASP.NET CORE如何实现跨域

从截图中可以看出,这次调用成功了。

3、设置特定来源可以跨域

3.1、修改ConfigureServices方法代码如下:
//允许一个或多个来源可以跨域services.AddCors(options =>{      options.AddPolicy("CustomCorsPolicy", policy =>      {             // 设定允许跨域的来源,有多个可以用','隔开             policy.WithOrigins("Http://localhost:21632")             .AllowAnyHeader()             .AllowAnyMethod()             .AllowCredentials();      });});

这里设置只允许ip为http://localhost:21632的来源允许跨域。

3.2、修改Configure代码如下:
// 设定特定ip允许跨域 CustomCorsPolicy是在ConfigureServices方法中配置的跨域策略名称app.UseCors("CustomCorsPolicy");
3.3测试

点击跨域测试1按钮,结果如下:

ASP.NET CORE如何实现跨域

可以看到访问成功了,然后在点击跨域测试2按钮,结果如下:

ASP.NET CORE如何实现跨域

发现这次访问失败了,F12进入Debug模式,查看失败原因:

ASP.NET CORE如何实现跨域

从截图中可以看出是因为这里产生了跨域请求,但是没有允许跨域测试2所在的ip跨域。那么如果也想让跨域测试2可以调用成功该怎么办呢?

光标定位到WithOrigins上面,然后F12查看定义:

ASP.NET CORE如何实现跨域

从截图中发现:WithOrigins的参数是一个params类型的字符串数组,如果要允许多个来源可以跨域,只要传一个字符串数组就可以了,所以代码修改如下:

//允许一个或多个来源可以跨域services.AddCors(options =>{      options.AddPolicy("CustomCorsPolicy", policy =>      {            // 设定允许跨域的来源,有多个可以用','隔开            policy.WithOrigins("http://localhost:21632", "http://localhost:24661")            .AllowAnyHeader()            .AllowAnyMethod()            .AllowCredentials();      });});

这时跨域测试2也可以调用成功了

ASP.NET CORE如何实现跨域

4、优化

在上面的例子中,需要分两步进行设置才可以允许跨域,有没有一种方法只需要设置一次就可以呢?在Configure方法中只设置一次即可,代码如下:

// 设置允许所有来源跨域app.UseCors(options =>{       options.AllowAnyHeader();       options.AllowAnyMethod();       options.AllowAnyOrigin();       options.AllowCredentials();});// 设置只允许特定来源可以跨域app.UseCors(options =>{        options.WithOrigins("http://localhost:3000", "http://127.0.0.1"); // 允许特定ip跨域        options.AllowAnyHeader();        options.AllowAnyMethod();        options.AllowCredentials();});

5、利用配置文件实现跨域

在上面的示例中,都是直接把ip写在了程序里面,如果要增加或者修改允许跨域的ip就要修改代码,这样非常不方便,那么能不能利用配置文件实现呢?看下面的例子。

5.1、修改appsettings.json文件如下:
{  "Logging": {    "LogLevel": {      "Default": "Warning"    }  },  "AllowedHosts": {    "url": "http://localhost:21632|http://localhost:24663"  }}

AllowedHosts里面设置的是允许跨域的ip,多个ip直接用“|”进行拼接,也可以用其他符合进行拼接。

5.2、增加CorsOptions实体类
using System;using System.Collections.Generic;using System.Linq;using System.Threading.Tasks;namespace CorsDomainDemo{    public class CorsOptions    {        public string url { get; set; }    }}
5.3、 新增OptionConfigure方法
private void OptionConfigure(IServiceCollection services){    services.Configure<CorsOptions>(Configuration.GetSection("AllowedHosts"));}
5.4、在ConfigureServices方法里面调用OptionConfigure方法
// 读取配置文件内容OptionConfigure(services);
5.5、修改Configure方法,增加IOptions<CorsOptions>类型的参数,最终代码如下
using System;using System.Collections.Generic;using System.Linq;using System.Threading.Tasks;using Microsoft.Aspnetcore.Builder;using Microsoft.AspNetCore.Hosting;using Microsoft.AspNetCore.HttpsPolicy;using Microsoft.AspNetCore.Mvc;using Microsoft.Extensions.Configuration;using Microsoft.Extensions.DependencyInjection;using Microsoft.Extensions.Logging;using Microsoft.Extensions.Options;namespace CorsDomainDemo{    public class Startup    {        public Startup(IConfiguration configuration)        {            Configuration = configuration;        }        public IConfiguration Configuration { get; }        // This method gets called by the runtime. Use this method to add services to the container.        public void ConfigureServices(IServiceCollection services)        {            // 配置跨域处理,允许所有来源            //services.AddCors(options =>            //options.AddPolicy("cors",            //p => p.AllowAnyOrigin().AllowAnyHeader().AllowAnyMethod().AllowCredentials()));            //允许一个或多个来源可以跨域            //services.AddCors(options =>            //{            //    options.AddPolicy("CustomCorsPolicy", policy =>            //    {            //        // 设定允许跨域的来源,有多个可以用','隔开            //        policy.WithOrigins("http://localhost:21632", "http://localhost:24661")            //          .AllowAnyHeader()            //           .AllowAnyMethod()            //           .AllowCredentials();            //    });            //});            // 读取配置文件内容            OptionConfigure(services);            services.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_1);        }        // This method gets called by the runtime. Use this method to configure the HTTP request pipeline.        public void Configure(IApplicationBuilder app, IHostingEnvironment env, IOptions<CorsOptions> corsOptions)        {            if (env.IsDevelopment())            {                app.UseDeveloperExceptionPage();            }            else            {                app.UseHsts();            }            // 允许所有跨域,cors是在ConfigureServices方法中配置的跨域策略名称            //app.UseCors("cors");            // 设定特定ip允许跨域 CustomCorsPolicy是在ConfigureServices方法中配置的跨域策略名称            //app.UseCors("CustomCorsPolicy");            // 设置允许所有来源跨域            //app.UseCors(options =>            //{            //    options.AllowAnyHeader();            //    options.AllowAnyMethod();            //    options.AllowAnyOrigin();            //    options.AllowCredentials();            //});            // 设置只允许特定来源可以跨域            //app.UseCors(options =>            //{            //    options.WithOrigins("http://localhost:3000", "http://127.0.0.1"); // 允许特定ip跨域            //    options.AllowAnyHeader();            //    options.AllowAnyMethod();            //    options.AllowCredentials();            //});            // 利用配置文件实现            CorsOptions _corsOption = corsOptions.Value;            // 分割成字符串数组            string[] hosts = _corsOption.url.Split('|');            // 设置跨域            app.UseCors(options =>            {                options.WithOrigins(hosts);                options.AllowAnyHeader();                options.AllowAnyMethod();                options.AllowCredentials();            });            app.UseHttpsRedirection();            app.UseMvc();        }        private void OptionConfigure(IServiceCollection services)        {            services.Configure<CorsOptions>(Configuration.GetSection("AllowedHosts"));        }    }}

这样就可以实现利用配置文件实现允许跨域了。

到此,相信大家对“ASP.NET CORE如何实现跨域”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

--结束END--

本文标题: ASP.NET CORE如何实现跨域

本文链接: https://www.lsjlt.com/news/324662.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • ASP.NET CORE如何实现跨域
    本篇内容主要讲解“ASP.NET CORE如何实现跨域”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“ASP.NET CORE如何实现跨域”吧!一、后台API接口用.net c...
    99+
    2023-06-29
  • ASP.NET CORE实现跨域
    目录一、后台API接口二、前端界面三、测试1、不设置允许跨域2、设置允许所有来源跨域2.1、在StartUp类的ConfigureServices方法中添加如下代码:2.2、修改Co...
    99+
    2022-11-13
  • ASP.NET的Core AD域登录过程怎么实现
    本文小编为大家详细介绍“ASP.NET的Core AD域登录过程怎么实现”,内容详细,步骤清晰,细节处理妥当,希望这篇“ASP.NET的Core AD域登录过程怎么实现”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入...
    99+
    2023-06-29
  • Angular如何实现跨域
    这篇文章主要介绍了Angular如何实现跨域,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。百度:url截取之后红色部分需替换 :https:...
    99+
    2022-10-19
  • ASP.NET Core如何使用AutoMapper实现实体映射
    这篇文章将为大家详细讲解有关ASP.NET Core如何使用AutoMapper实现实体映射,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、前言在实际的项目开发过程中,我们使用各种ORM框架可...
    99+
    2023-06-29
  • ASP.NET Core中如何实现重定向详解
    前言 ASP.NET Core 是一个跨平台,开源的,轻量级的,模块化的,用于构建高性能的 web 开发框架, ASP.NET Core MVC 内置了多种方式将一个 requ...
    99+
    2022-06-07
    重定向 ASP.NET net core ASP
  • ASP.NET Core中如何MockUrl.Page()
    今天就跟大家聊聊有关ASP.NET Core中如何MockUrl.Page(),可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。在 ASP.NET Co...
    99+
    2022-10-19
  • ASP.NET Core如何注入多个服务实现类
    目录1、定义个接口2、注入服务 3、功能类 4、高级类前言: 依赖注入在 ASP.NET Core 中起中很重要的作用,也是一种高大上的编程思想,它的总体原则就是...
    99+
    2022-11-12
  • asp.net Core中如何实现同名服务注册
    这篇文章主要为大家展示了“asp.net Core中如何实现同名服务注册”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“asp.net Core中如何实现同名服务注册”这篇文章...
    99+
    2023-06-29
  • php如何实现跨域请求
    本文操作环境:windows10系统、php 7、thinkpad t480电脑。在PHP中如果我们需要实现跨域,可以通过设置Access-Control-Allow-Origin来实现。接下来我们举个例子,方便大家更好地理解。假设现在的客...
    99+
    2017-05-30
    php 跨域请求
  • Ajax如何实现跨域访问
    这篇文章主要为大家展示了“Ajax如何实现跨域访问”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Ajax如何实现跨域访问”这篇文章吧。一、什么是跨域我们先回顾一...
    99+
    2022-10-19
  • 如何在JavaScript中实现跨域
    如何在JavaScript中实现跨域?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。JavaScript的特点1.JavaScript主要用来向HTML页面添加交...
    99+
    2023-06-06
  • ASP.NET Core实时库SignalR如何使用
    这篇文章主要讲解了“ASP.NET Core实时库SignalR如何使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“ASP.NET Core实时库SignalR如何使用...
    99+
    2023-06-26
  • ASP.NET Core如何读取Request.Body
    这篇文章主要介绍ASP.NET Core如何读取Request.Body,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!常用读取方式当我们要读取Request Body的时候,相信大家第一直觉和笔者是一样的,这有啥难的...
    99+
    2023-06-15
  • 详解如何在ASP.Net Core中实现健康检查
    健康检查 常用于判断一个应用程序能否对 request 请求进行响应,ASP.Net Core 2.2 中引入了 健康检查 中间件用于报告应用程序的健康状态。 ASP.Net Cor...
    99+
    2022-11-11
  • 如何在Asp.Net Core MVC中处理null值的实现
    译文链接:https://www.infoworld.com/article/3434624/how-to-handle-null-values-in-aspnet-core-...
    99+
    2022-06-07
    ASP.NET core null MVC ASP net
  • ASP.NET Core通用主机如何实现托管服务
    本文小编为大家详细介绍“ASP.NET Core通用主机如何实现托管服务”,内容详细,步骤清晰,细节处理妥当,希望这篇“ASP.NET Core通用主机如何实现托管服务”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入...
    99+
    2023-07-02
  • Asp.net core中依赖注入的实现
    使用服务 在Asp.net core的Controller中,可以通过如下两种方式获取系统注入的服务: 构造函数 可以直接在构造函数中传入所依赖的服务,这是非常常见的DI注入方式。 ...
    99+
    2022-11-13
  • Asp.NET Core 限流控制(AspNetCoreRateLimit)的实现
    起因: 近期项目中,提供了一些调用频率较高的api接口,需要保障服务器的稳定运行;需要对提供的接口进行限流控制。避免因客户端频繁的请求导致服务器的压力。 一、AspNetCoreRa...
    99+
    2022-11-11
  • Asp.Net Core 中的“虚拟目录”实现
    写在前面   现在部署Asp.Net Core应用已经不再限制于Windows的IIS上,更多的是Docker容器、各种反向代理来部署。也有少部分用IIS部署的,IIS部署确实...
    99+
    2022-06-07
    net ASP ASP.NET 虚拟目录 core
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作