(精华)2020年7月1日 ASP.NET Core 解决跨域问题(手写版)

using Microsoft.AspNetCore.Http;
using System.Threading.Tasks;

namespace Core.Api
{
     
    /// 
    /// 跨域中间件
    /// 
    public class CorsMiddleware
    {
     
        private readonly RequestDelegate _next;

        /// 
        /// 管道执行到该中间件时候下一个中间件的RequestDelegate请求委托,如果有其它参数,也同样通过注入的方式获得
        /// 
        /// 下一个处理者
        public CorsMiddleware(RequestDelegate next)
        {
     
            _next = next;
        }

        /// 
        /// 自定义中间件要执行的逻辑
        /// 
        /// 
        /// 
        public async Task Invoke(HttpContext context)
        {
     
            context.Response.Headers.Add("Access-Control-Allow-Origin", "*");
            context.Response.Headers.Add("Access-Control-Allow-Headers", context.Request.Headers["Access-Control-Request-Headers"]);
            context.Response.Headers.Add("Access-Control-Allow-Methods", "GET, POST, PUT, DELETE, OPTIONS");

            //若为OPTIONS跨域请求则直接返回,不进入后续管道
            if (context.Request.Method.ToUpper() != "OPTIONS")
                await _next(context);//把context传进去执行下一个中间件
        }
    }
}
public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
{
     
    app.UseMiddleware<CorsMiddleware>()//跨域
}

你可能感兴趣的:(#,ASP.NET,Core,c#,asp.net,后端)