私のASP.Net Core 1.1では。バックエンド私は次のようにCORSを有効にしました:ASP.Netコア1.1 Angular2 PUTリクエストがアクセス制御元なしなし
public void ConfigureServices(IServiceCollection services)
{
// Add framework services.
services.AddDbContext<WebAPIDataContext>(options =>
{
options.UseMySql(Configuration.GetConnectionString("MysqlConnection"));
});
services.AddScoped<IProfileRepository, ProfileRepository>();
services.AddScoped<IUser_TaskRepository, User_TaskRepository>();
services.AddCors(options =>
{
options.AddPolicy("CorsPolicy",
builder => builder.AllowAnyOrigin()
.AllowAnyMethod()
.AllowAnyHeader());
});
services.AddMvc();
services.AddSwaggerGen(c =>
{
c.SwaggerDoc("v1", new Info { Title = "My API", Version = "v1" });
});
}
// This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
public void Configure(IApplicationBuilder app, IHostingEnvironment env, ILoggerFactory loggerFactory)
{
loggerFactory.AddConsole(Configuration.GetSection("Logging"));
loggerFactory.AddDebug();
// global policy - assign here or on each controller
app.UseCors("CorsPolicy");
app.UseMvc();
// Enable middleware to serve generated Swagger as a JSON endpoint.
app.UseSwagger();
// Enable middleware to serve swagger-ui (HTML, JS, CSS etc.), specifying the Swagger JSON endpoint.
app.UseSwaggerUI(c =>
{
c.SwaggerEndpoint("/swagger/v1/swagger.json", "My API V1");
});
}
私のangular2フロントエンドから、私はPOSTとPUTリクエストをしています。 POSTは成功したがPUTは私に何'Access-Control-Allow-Origin' header is present on the requested resource.
を与えない障害が発生した彼らは、次のとおりです。
private base_url = 'http://localhost:4783/api/';
constructor (private http: Http) {}
createProfile(profile: ProfileModel): Observable<ProfileModel[]>{
let headers = new Headers({ 'Access-Control-Allow-Origin': '*' });
let options = new RequestOptions({ headers: headers });
return this.http.post(this.base_url + 'Profile', profile , options)
.map(this.extractData)
.catch(this.handleError);
}
updateProfile(profile: ProfileModel, profileId: number): Observable<ProfileModel[]>{
console.log(profile, profileId)
let headers = new Headers({ 'Access-Control-Allow-Origin': '*' });
let options = new RequestOptions({ headers: headers});
return this.http.put(this.base_url + 'Profile' + '/' + profileId, profile , options)
.map(this.extractData)
.catch(this.handleError);
}
私が間違って何をしているのですか?