Asp.Netcore使用拦截器后跨域问题解决

aspnetcore在使用拦截器【无论是官方的filter还是第三方封装的】后,跨域中间件Cors会失去效果。

第一种方法在注入拦截器里面也载入跨域中间件

  .AddMvc(options =>
            {
                #region 拦截器配置
                options.Filters.Add(new CorsAuthorizationFilterFactory("SignalRCore"));

    });

允许所有访问的跨域中间件的写法

  services.AddCors(options =>
            {
                options.AddPolicy("SignalRCore",
                    policy => policy.AllowAnyOrigin()
                                    .AllowAnyHeader()
                                    .AllowAnyMethod()
                                    .AllowCredentials());
            })

第二种方法需要在返回信息的头里面添加手动添加跨域允许 

Access-Control-Allow-Origin=*   (添加在header里面,*可以替换成对方的域名)

 

已官方的filter拦截器为例:

这里我只在执行前拦截去添加了。因为所有的拦截这一步是肯定要走的。在这添加了即可

 

 

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值