博主信息
博文 15
粉丝 0
评论 0
访问量 27736
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
ASP.NET CORE实现跨域
P粉622841118
原创
1863人浏览过

目录
一、后台API接口
二、前端界面
三、测试
1、不设置允许跨域
2、设置允许所有来源跨域
2.1、在StartUp类的ConfigureServices方法中添加如下代码:
2.2、修改Configure方法
2.3、测试
3、设置特定来源可以跨域
3.1、修改ConfigureServices方法代码如下:
3.2、修改Configure代码如下:
3.3测试
4、优化
5、利用配置文件实现跨域
5.1、修改appsettings.json文件如下:
5.2、增加CorsOptions实体类
5.3、新增OptionConfigure方法
5.4、在ConfigureServices方法里面调用OptionConfigure方法
5.5、修改Configure方法,增加IOptions<CorsOptions>类型的参数,最终代码如下

一、后台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按钮:


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.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;
}

  1. public IConfiguration Configuration { get; }
  2. // This method gets called by the runtime. Use this method to add services to the container.
  3. public void ConfigureServices(IServiceCollection services)
  4. {
  5. // 配置跨域处理,允许所有来源
  6. //services.AddCors(options =>
  7. //options.AddPolicy("cors",
  8. //p => p.AllowAnyOrigin().AllowAnyHeader().AllowAnyMethod().AllowCredentials()));
  9. //允许一个或多个来源可以跨域
  10. //services.AddCors(options =>
  11. //{
  12. // options.AddPolicy("CustomCorsPolicy", policy =>
  13. // {
  14. // // 设定允许跨域的来源,有多个可以用','隔开
  15. // policy.WithOrigins("http://localhost:21632", "http://localhost:24661")
  16. // .AllowAnyHeader()
  17. // .AllowAnyMethod()
  18. // .AllowCredentials();
  19. // });
  20. //});
  21. // 读取配置文件内容
  22. OptionConfigure(services);
  23. services.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_1);
  24. }
  25. // This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
  26. public void Configure(IApplicationBuilder app, IHostingEnvironment env, IOptions<CorsOptions> corsOptions)
  27. {
  28. if (env.IsDevelopment())
  29. {
  30. app.UseDeveloperExceptionPage();
  31. }
  32. else
  33. {
  34. app.UseHsts();
  35. }
  36. // 允许所有跨域,cors是在ConfigureServices方法中配置的跨域策略名称
  37. //app.UseCors("cors");
  38. // 设定特定ip允许跨域 CustomCorsPolicy是在ConfigureServices方法中配置的跨域策略名称
  39. //app.UseCors("CustomCorsPolicy");
  40. // 设置允许所有来源跨域
  41. //app.UseCors(options =>
  42. //{
  43. // options.AllowAnyHeader();
  44. // options.AllowAnyMethod();
  45. // options.AllowAnyOrigin();
  46. // options.AllowCredentials();
  47. //});
  48. // 设置只允许特定来源可以跨域
  49. //app.UseCors(options =>
  50. //{
  51. // options.WithOrigins("http://localhost:3000", "http://127.0.0.1"); // 允许特定ip跨域
  52. // options.AllowAnyHeader();
  53. // options.AllowAnyMethod();
  54. // options.AllowCredentials();
  55. //});
  56. // 利用配置文件实现
  57. CorsOptions _corsOption = corsOptions.Value;
  58. // 分割成字符串数组
  59. string[] hosts = _corsOption.url.Split('|');
  60. // 设置跨域
  61. app.UseCors(options =>
  62. {
  63. options.WithOrigins(hosts);
  64. options.AllowAnyHeader();
  65. options.AllowAnyMethod();
  66. options.AllowCredentials();
  67. });
  68. app.UseHttpsRedirection();
  69. app.UseMvc();
  70. }
  71. private void OptionConfigure(IServiceCollection services)
  72. {
  73. services.Configure<CorsOptions>(Configuration.GetSection("AllowedHosts"));
  74. }
  75. }

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

本博文版权归博主所有,转载请注明地址!如有侵权、违法,请联系admin@php.cn举报处理!
全部评论 文明上网理性发言,请遵守新闻评论服务协议
0条评论
作者最新博文
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号

  • 登录PHP中文网,和优秀的人一起学习!
    全站2000+教程免费学