相关疑难解决方法(0)

asp net core - 请求的资源上没有"Access-Control-Allow-Origin"标头

我设置了两个网络核心应用程序(netcoreapp2.0).

一个是负核心webapi(后端应用程序),负责将数据返回给用户.此应用程序在http:// localhost:5001上运行

另一个是在core.cshtml中加载角度的网络核心webapp(前端应用程序).此应用程序在http:// localhost:5000上运行

我遇到的问题是,在api中将[Authorize]设置为我的控制器之后,我在请求的资源错误上出现No'Access-Control-Allow-Origin'标头

这包含在web api项目的启动中:

    public void ConfigureServices(IServiceCollection services)
    {
        ..................................

        services.AddCors(options =>
        {
            options.AddPolicy("AllowAll",
                    builder =>
                    {
                        builder.WithOrigins("http://localhost:5000")
                               .AllowAnyMethod()
                               .AllowAnyHeader()
                               .AllowCredentials()
                               .WithExposedHeaders("Authorization", "WWW-Authenticate");
                    });
        });

        services
            .AddMvcCore()
            .AddJsonFormatters()
            .AddAuthorization();

        ..................................
    }

    public void Configure(IApplicationBuilder app)
    {
        ...................................

        app.UseCors("AllowAll");

        app.UseMvc(routes =>
        {
            routes.MapRoute(
                name: "default",
                template: "{controller=Home}/{action=Index}/{id?}");
        });

        ...................................           

    }
Run Code Online (Sandbox Code Playgroud)

控制器类有:[EnableCors("AllowAll")]其中AllowAll是我在上面启动时设置的策略的名称

这里还有angular中的代码,它返回请求中设置的标头:

getAuthHeaders(): Headers {
    if (this.oauthService.hasValidAccessToken) {
        var headers = new Headers();
        headers.set('Accept', '*/*');
        headers.set('Access-Control-Allow-Credentials', 'true');
        headers.set('Authorization', 'Bearer ' + this.oauthService.getAccessToken()); …
Run Code Online (Sandbox Code Playgroud)

cors oauth-2.0 asp.net-core angular

7
推荐指数
1
解决办法
4277
查看次数

标签 统计

angular ×1

asp.net-core ×1

cors ×1

oauth-2.0 ×1