2017-09-13 2 views
0

J'ai un problème avec la demande get dans angulaire 2. J'ai une méthode pour obtenir des documents:angulaire 2: Réponse de prévol est invalide (redirect)

getDocuments() { 
    let username: string = 'username'; 
    let password: string = 'password'; 
    let headers: Headers = new Headers(); 
    headers.append("Authorization", "Basic " + btoa(username + ":" + password)); 
    headers.append("Content-Type", "multipart/form-data"); 
    return this._http.get('http://localhost:8080/api/documents', {headers: headers}).map(res => res.json()); 
} 

Et il y a une erreur:

Response for preflight is invalid (redirect)

Solution, il a travaillé pour moi (ajouté à l'application de SpringBoot):

@Bean 
public FilterRegistrationBean corsFilter() { 
    UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource(); 
    org.springframework.web.cors.CorsConfiguration config = new org.springframework.web.cors.CorsConfiguration(); 
    config.setAllowCredentials(true); 
    config.addAllowedOrigin("http://localhost:4200"); 
    config.setAllowedMethods(Arrays.asList("POST", "OPTIONS", "GET", "DELETE", "PUT")); 
    config.setAllowedHeaders(Arrays.asList("X-Requested-With", "Origin", "Content-Type", "Accept", "Authorization")); 
    source.registerCorsConfiguration("/**", config); 
    FilterRegistrationBean bean = new FilterRegistrationBean(new CorsFilter(source)); 
    bean.setOrder(Ordered.HIGHEST_PRECEDENCE); 
    return bean; 
} 
+3

Vous devez configurer le serveur pour autoriser CORS. –

+0

Je l'ai fait (ajouté @CrossOrigin (origines = "http: // localhost: 4200") dans SpringBoot) et cela ne fonctionne toujours pas. – Helosze

+1

Je ne connais pas votre serveur. Je sais que ce n'est pas lié à Angular. Il y a probablement d'autres options de configuration manquantes. –

Répondre

0

Cette question est sur le point d'obtenir une réponse REST, mais le ser ver renvoie une redirection. Cela ne correspond pas.

J'ai fait quelques tests avec Angular/SpringBoot/Oauth2 dans cette zone, donc, c'est pourquoi je pourrais répondre à cette situation exacte.