F#WebApi Cors不起作用

Ema*_*rsa 5 f# unauthorized cors asp.net-web-api2

我正在尝试创建一个写入F#并启用的WebApi项目CORS.
控制者:

type DoItController() =
    inherit ApiController()

    [<EnableCors(origins = "*", headers = "*", methods = "Get")>]
    [<HttpGet>]
    [<Route "api/GetGenerateExcel">]
    member __.GetGenerateExcel() =
        async {
            // Some code
            return "It works"

        } 
        |> Async.StartAsTask


}
Run Code Online (Sandbox Code Playgroud)

直接从它工作的浏览器打开它.通过调用它AngularJS或纯Javascript我得到401.

C#中的等效控制器工作原理:

public class DoItController : ApiController
    {
        [EnableCors("*", "*", "Get")]
        [HttpGet]
        [Route("api/GetGenerateExcel")]
        public async Task<string> GetGenerateExcel()
        {
            //Some code
            return "It works"
        }
    }
Run Code Online (Sandbox Code Playgroud)

我也查了一下Global.asax,他们也匹配:

type Global() =
    inherit HttpApplication()

    static member RegisterWebApi(config: HttpConfiguration) =

        config.EnableCors()
        config.MapHttpAttributeRoutes()
        config.Formatters.Remove(config.Formatters.XmlFormatter) |> ignore

    member x.Application_Start() =
        GlobalConfiguration.Configure(Action<_> Global.RegisterWebApi)

public class Global : HttpApplication
    {
        protected void Application_Start()
        {
            GlobalConfiguration.Configure(config =>
            {
                config.EnableCors();
                config.MapHttpAttributeRoutes();
                config.Formatters.Remove(config.Formatters.XmlFormatter);
            });
        }
    }
Run Code Online (Sandbox Code Playgroud)

我检查了所有的nuget包,他们匹配.此外,web.config没有可能影响功能的差异.

我还能检查或测试什么?

编辑:
以下是我的Javascript部分,如果withcredentials = true添加(也在服务器上)它的工作原理:

var request = new XMLHttpRequest();
request.open('GET', url, true);

request.onload = function() {
    if (request.status >= 200 && request.status < 400) {
        // Success!
    }
}

request.onerror = function() {
    //Error
}

request.send();
Run Code Online (Sandbox Code Playgroud)

AngularJS:

$http.get(url).then(function(response){
    // Success!
}, function(error){
   // Error
}
Run Code Online (Sandbox Code Playgroud)

Eri*_*ric 2

所以我的做法有点不同,但我相信同样的概念适用。我的也是 C# 语言,所以忽略这些差异。

在我的 WebApiConfig.cs 中

 using System.Web.Http.Cors;

 var cors = new EnableCorsAttribute("*", "*", "GET,POST,PUT,OPTIONS");

 cors.SupportsCredentials = true;
 config.EnableCors(cors);
 config.MapHttpAttributeRoutes();

 config.Routes.MapHttpRoute(
    name: "DefaultApi",
    routeTemplate: "api/{controller}/{id}",
    defaults: new { id = RouteParameter.Optional }
 );
Run Code Online (Sandbox Code Playgroud)

当我使用 jQuery 或 JavaScript 访问时,我需要通过 jQuery 请求发送以下内容。这是授权用户访问的权限。

xhrFields : {withCredentials: true}
Run Code Online (Sandbox Code Playgroud)

我不像您那样使用 Global.asax 中的任何代码,因为这是我注册所有指向 App_Start 文件夹中关联类的配置内容的地方。

我的 globabl.asax 看起来像这样

protected void Application_Start()
{
    AreaRegistration.RegisterAllAreas();
    GlobalConfiguration.Configure(WebApiConfig.Register);
    FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);
    RouteConfig.RegisterRoutes(RouteTable.Routes);
    BundleConfig.RegisterBundles(BundleTable.Bundles);
}
Run Code Online (Sandbox Code Playgroud)

请注意,我个人使用的方法是使用 xml 文件来存储可以访问 webapi 应用程序的授权域。代码有点不同,但如果它对任何人有帮助,我可以发布它。