I'm trying to call the API from angular and getting this errors. I donot want to set proxy in angular instead allow CORS in Angular 4 and Web API.
Following is my code:
let reHeader: RequestOptions = new RequestOptions();
reHeader.headers = new Headers();
reHeader.headers.append("content-type", "application/json");
reHeader.headers.append("x-api-key", store.APIKey);
reHeader.headers.append('Access-Control-Allow-Origin','*');
reHeader.headers.append('Access-Control-Allow-Methods', "GET, POST, PATCH, PUT, DELETE, OPTIONS")
reHeader.headers.append('Access-Control-Allow-Headers', "Origin, Content-Type, X-Auth-Token")
switch (rtype) {
case "get":
let query: string = "";
action.ActionParams.forEach(m => {
query += "&" + m.Key + "=" + m.Value;
});
url = url + query;
return this.http.get(url, reHeader);
default:
return Observable.of(null);
}
and from WEB API in startup.cs
public void Configuration(IAppBuilder app)
{
app.UseCors(Microsoft.Owin.Cors.CorsOptions.AllowAll);
// ASPNETCORE_ENVIRONMENT should be set to 'Development'
if (env != null && env.IsDevelopment())
{
app.UseErrorPage(ErrorPageOptions.ShowAll);
}
var config = new HttpConfiguration();
ConfigureWebApi(config);
// Swagger
SwaggerConfig.Register(config);
// Register routes
WebApiConfig.Register(config);
}
I have checked other posts but still didnt get solution. - Angular 2 Response to preflight request doesn't pass access control check: No 'Access-Control-Allow-Origin' header