小编Ger*_*zzi的帖子

.NetCore SignalR + React - CORS 调用不起作用

我有一个 SignalR 问题,在协商阶段,我从一个 ReactJS 站点调用到一个 .net core signalR 集线器,错误是 CORS 标头不存在,我已经启动了 CORS 并正在工作,因为整个站点调用另一台服务器中的后端,所有调用都工作正常。

这是我得到的错误:

对预检请求的响应未通过访问控制检查:请求的资源上不存在“Access-Control-Allow-Origin”标头。因此,不允许访问来源“ http://localhost:8080 ”。

这是客户端代码:

SignalR() {
    const connection = new signalR.HubConnectionBuilder()
      .withUrl(process.env.API_URL + "/HealthMonitorHub", options => {
        options.UseDefaultCredentials = true;
    })
    .build();
    connection
      .start()
      .then(() => console.log('Connection started!'))
      .catch(err => console.log('Error while establishing connection => ' + err));
  }
Run Code Online (Sandbox Code Playgroud)

这是服务器端网络核心启动:

public void ConfigureServices(IServiceCollection services)
{
    services.AddSignalR();
    services.AddCors(o => o.AddPolicy("CorsPolicy", builder =>
    {
        builder.AllowAnyMethod()
        .AllowAnyHeader()
        .WithOrigins("*")
        .AllowCredentials();
    }));
    services.Configure<MvcOptions>(options =>
    {
         options.Filters.Add(new CorsAuthorizationFilterFactory("CorsPolicy"));
    });
    services.AddMvc();
 }

 public …
Run Code Online (Sandbox Code Playgroud)

.net signalr reactjs

6
推荐指数
1
解决办法
2344
查看次数

标签 统计

.net ×1

reactjs ×1

signalr ×1