新开传奇网站发布网中变,网站建设话术开场白,萧山区住房和城乡建设局网站,网站备案 材料什么是跨域在前面已经讲解过了#xff0c;这里便不再讲解#xff0c;直接上代码。 一、后台API接口 用.net core创建一个Web API项目负责给前端界面提供数据。 二、前端界面 建立两个MVC项目#xff0c;模拟不同的ip#xff0c;在view里面添加按钮调用WEB API提供的接口进行…什么是跨域在前面已经讲解过了这里便不再讲解直接上代码。 一、后台API接口 用.net core创建一个Web API项目负责给前端界面提供数据。 二、前端界面 建立两个MVC项目模拟不同的ip在view里面添加按钮调用WEB API提供的接口进行测试跨域。view视图页代码如下 {Layout null;
}!DOCTYPE htmlhtml
headmeta nameviewport contentwidthdevice-width /title跨域测试1/titlescript src~/Scripts/jquery-1.10.2.js/scriptscriptfunction btnGet() {$.ajax({url: https://localhost:44355/api/values,type: Get,dataType: json,success: function (data) {alert(成功);},error: function (data) {alert(失败);}});}/script
/head
bodydiv input typebutton idbtn value测试跨域 οnclickbtnGet() //div
/body
/html 三、测试 1、不设置允许跨域 首先先不设置.net core允许跨域查看调用效果 点击测试跨域1按钮 F12进入Debug模式查看失败原因 从这里可以看出来是因为产生了跨域问题所以会失败。 点击测试跨域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、测试 从截图中可以看出这次调用成功了。 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按钮结果如下 可以看到访问成功了然后在点击跨域测试2按钮结果如下 发现这次访问失败了F12进入Debug模式查看失败原因 从截图中可以看出是因为这里产生了跨域请求但是没有允许跨域测试2所在的ip跨域。那么如果也想让跨域测试2可以调用成功该怎么办呢 光标定位到WithOrigins上面然后F12查看定义 从截图中发现WithOrigins的参数是一个params类型的字符串数组如果要允许多个来源可以跨域只要传一个字符串数组就可以了所以代码修改如下 //允许一个或多个来源可以跨域
services.AddCors(options
{options.AddPolicy(CustomCorsPolicy, policy {// 设定允许跨域的来源有多个可以用,隔开policy.WithOrigins(http://localhost:21632, http://localhost:24661).AllowAnyHeader().AllowAnyMethod().AllowCredentials();});
}); 这时跨域测试2也可以调用成功了 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.ConfigureCorsOptions(Configuration.GetSection(AllowedHosts));
} 5.4、在ConfigureServices方法里面调用OptionConfigure方法 // 读取配置文件内容
OptionConfigure(services); 5.5、修改Configure方法增加IOptionsCorsOptions类型的参数最终代码如下 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, IOptionsCorsOptions 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.ConfigureCorsOptions(Configuration.GetSection(AllowedHosts));}}
} 这样就可以实现利用配置文件实现允许跨域了。转载于:https://www.cnblogs.com/dotnet261010/p/10177166.html