SpringのCORS設定方法

Springでのクロスオリジンの設定方法は以下のとおりです。

  1. @CrossOriginアノテーションを使う方法:@CrossOriginアノテーションはControllerのクラスやメソッドに直接追加でき、許可されるオリジンのドメインを指定します。例:@CrossOrigin(origins = “http://example.com”)。
  2. クラスを WebMvcConfigurer インターフェイスにインプリメントしてCorsRegistryオブジェクトでクロスオリジンリソース共有に関するルールを構成することにより、Java設定クラスWebMvcConfigurer を使用します。
@Configuration
public class WebMvcConfig implements WebMvcConfigurer {
    @Override
    public void addCorsMappings(CorsRegistry registry) {
        registry.addMapping("/api/**")
                .allowedOrigins("http://example.com")
                .allowedMethods("GET", "POST")
                .allowCredentials(true)
                .maxAge(3600);
    }
}
  1. CORSフィルタ
  2. Web.xml
  3. CORSフィルタ
<filter>
    <filter-name>CorsFilter</filter-name>
    <filter-class>org.springframework.web.filter.CorsFilter</filter-class>
    <init-param>
        <param-name>cors.allowed.origins</param-name>
        <param-value>http://example.com</param-value>
    </init-param>
    <init-param>
        <param-name>cors.allowed.methods</param-name>
        <param-value>GET,POST</param-value>
    </init-param>
    <init-param>
        <param-name>cors.allow.credentials</param-name>
        <param-value>true</param-value>
    </init-param>
    <init-param>
        <param-name>cors.max.age</param-name>
        <param-value>3600</param-value>
    </init-param>
</filter>

<filter-mapping>
    <filter-name>CorsFilter</filter-name>
    <url-pattern>/api/*</url-pattern>
</filter-mapping>

状況によって適切な方法を選択し、クロスドメインを設定できます。

bannerAds