Heim > Java > javaLernprogramm > Warum erhalte ich nach dem Hinzufügen von Spring Security die Fehlermeldung „Kein Header „Access-Control-Allow-Origin' vorhanden''?

Warum erhalte ich nach dem Hinzufügen von Spring Security die Fehlermeldung „Kein Header „Access-Control-Allow-Origin' vorhanden''?

DDD
Freigeben: 2024-10-31 01:43:29
Original
461 Leute haben es durchsucht

Why Am I Getting a

Spring Security CORS-Filter: Fehlerbehebung „Es ist kein ‚Access-Control-Allow-Origin‘-Header vorhanden“

Erklärung

Das Hinzufügen von Spring Security zu einem vorhandenen Projekt kann bei CORS-Anfragen (Cross-Origin Resource Sharing) den Fehler „Kein ‚Access-Control-Allow-Origin‘-Header vorhanden“ auslösen. Dieser Fehler tritt auf, weil der Access-Control-Allow-Origin-Antwortheader nicht zu Anfragen hinzugefügt wird.

Lösung

Methode 1:

Aktualisieren Sie Ihren Code, um die integrierte CORS-Unterstützung von Spring Security zu nutzen. Fügen Sie Ihrer Anwendung die folgende Konfiguration hinzu:

<code class="java">@Configuration
public class WebConfig extends WebMvcConfigurerAdapter {

    @Override
    public void addCorsMappings(CorsRegistry registry) {
        registry.addMapping("/**")
                .allowedMethods("HEAD", "GET", "PUT", "POST", "DELETE", "PATCH");
    }
}</code>
Nach dem Login kopieren

Methode 2:

Wenn Sie mehr Kontrolle über die CORS-Konfiguration wünschen, verwenden Sie den folgenden Ansatz:

<code class="java">@Configuration
public class SecurityConfig extends WebSecurityConfigurerAdapter {
    @Override
    protected void configure(HttpSecurity http) throws Exception {
        http.cors();
    }

    @Bean
    public CorsConfigurationSource corsConfigurationSource() {
        final CorsConfiguration configuration = new CorsConfiguration();
        configuration.setAllowedOrigins(ImmutableList.of("*"));
        configuration.setAllowedMethods(ImmutableList.of("HEAD",
                "GET", "POST", "PUT", "DELETE", "PATCH"));
        configuration.setAllowCredentials(true);
        configuration.setAllowedHeaders(ImmutableList.of("Authorization", "Cache-Control", "Content-Type"));
        final UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource();
        source.registerCorsConfiguration("/**", configuration);
        return source;
    }
}</code>
Nach dem Login kopieren

Zusätzliche Hinweise:

  • Vermeiden Sie die Verwendung von http.authorizeRequests().antMatchers(HttpMethod.OPTIONS, "/**").permitAll(); oder web.ignoring().antMatchers(HttpMethod.OPTIONS);, da es sich um falsche Lösungen handelt.
  • Stellen Sie sicher, dass Ihr CORS-Filter nach SecurityContextPersistenceFilter und vor LogoutFilter in der Filterkette positioniert ist.
  • Stellen Sie sicher, dass der Header „Access-Control-Allow-Methods“ die erforderlichen HTTP-Verben enthält: GET, PUT, POST usw.
  • Wenn der CORS-Fehler weiterhin auftritt, überprüfen Sie die Protokolle Ihrer Anwendung auf zusätzliche Informationen, die hilfreich sein könnten Lokalisieren Sie das Problem.

Das obige ist der detaillierte Inhalt vonWarum erhalte ich nach dem Hinzufügen von Spring Security die Fehlermeldung „Kein Header „Access-Control-Allow-Origin' vorhanden''?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage