当前位置: 首页 > 知识库问答 >
问题:

对起飞前请求的响应没有通过权限改造检查

孙乐逸
2023-03-14

选项https://dev-01-api-apptracker2/管理员401(未经授权)

从源https://dev-01-web-apptracker2在'https://dev-01-api-apptracker2/Admin'访问XMLHttpRequest'已被CORS策略阻止:对起飞前请求的响应不通过权限改造检查:请求的资源上不存在'Access-Control-允许-Origin'标头。

但是我想我已经在我的ajax代码中添加了一个标题“访问-控制-允许-起源': '*' ,并尝试了许多方法来解决这些CORS问题,我设置了dataType:“json”,交叉域:真,和凭据:真,并添加了不同的起源域。但是我仍然会出错。我不知道这有什么问题,有人可以帮我。谢谢!!

AddAdmin: function (callback, UserId) {
        $.ajax({
            headers: {
                'Accept': 'application/json',
                'Content-Type': 'application/json',
                'Access-Control-Allow-Headers': 'origin, X-Custom-Header',
                'Access-Control-Allow-Method': 'POST',
                'Access-Control-Allow-Origin': '*'
            },
            contentType: 'application/json',
            method: "POST",
            url: Services.APIBaseUrl + "Admin",
            dataType: 'json',
            crossDomain: true,
            data: JSON.stringify(UserId),
            xhrFields: {
                withCredentials: true
            },
            complete: function (data) {
                callback(data);
            }
        });
    },
public void ConfigureServices(IServiceCollection services)
        {
            services.AddCors(options =>
            {
                options.AddPolicy("APIAllowedOriginsPolicy",
                builder =>
                {
                    builder.WithOrigins("https://dev-01-web-apptracker2",
                        "http://localhost:31474")
                        .AllowAnyHeader()
                        .AllowAnyMethod()
                        .AllowCredentials();
                });
            });
            services.Configure<MvcOptions>(options =>
            {
                options.Filters.Add(new CorsAuthorizationFilterFactory("APIAllowedOriginsPolicy"));
            });
            services.AddAuthentication(IISDefaults.AuthenticationScheme);

            // Add framework services.
            services
                .AddMvc()
                .AddJsonOptions(options =>
                {
                    options.SerializerSettings.ContractResolver = new DefaultContractResolver();
                });
        }

public void Configure(IApplicationBuilder app, IHostingEnvironment env, ILoggerFactory loggerFactory)
        {

            //app.UseCors("APIAllowedOriginsPolicy");

            app.UseCors(builder =>
                builder.AllowAnyOrigin()
                        .AllowAnyMethod()
                        .AllowAnyHeader()
                        .AllowCredentials()
            );

            app.UseMvc();
        }

共有1个答案

司空高义
2023-03-14

我发现问题是因为IIS身份验证问题,它需要同时允许CORS的windows身份验证和匿名。

 类似资料: