Immer erhaltene Methode DELETE ist in der Preflight-Antwort von Access-Control-Allow-Methods nicht zulässig.
Ich verwende Jersey als meine erholsame API-Implementierung. Im Front-End verwende ich Angularjs $ http-Dienst, um http-Anforderungen zu stellen. Wenn ich eine Löschmethode anfordere, ist mir immer der Fehler unterlaufen.
"Method DELETE is not allowed by Access-Control-Allow-Methods in preflight response."
Ich habe einige Artikel gelesen und sie sagen, ich muss das Löschen für "Zugriffskontroll-Zulassen-Methoden" zulassen. Ich habe den Antwortfilter wie folgt eingerichtet, aber es gibt immer noch ein solches Problem. Was soll ich sonst machen
@Provider
public class CORSResponseFilter implements ContainerResponseFilter {
@Override
public void filter(ContainerRequestContext requestContext, ContainerResponseContext responseContext) throws IOException {
MultivaluedMap<String, Object> headers = responseContext.getHeaders();
headers.add("Access-Control-Allow-Origin", "*");
headers.add("Access-Control-Allow-Methods", "*");
}
}
below ist mein Winkelcode, um die Anfrage zu stellen:
$http({
method: 'DELETE',
url: remoteUrl,
headers : {'Content-Type': 'application/x-www-form-urlencoded;charset=utf-8',
'ACCESS_TOKEN' : $cookieStore.get("access_token")
},
data : $httpParamSerializer({
'id':id
})
}).success(function(data,status,headers,config) {
$scope.refreshDepartments();
console.log(data);
alert("success");
}).error(function(data,status,headers,config){
console.log(data);
alert("error");
});