Spring Boot - Dukungan CORS
Cross-Origin Resource Sharing (CORS) adalah konsep keamanan yang memungkinkan pembatasan sumber daya yang diterapkan di browser web. Ini mencegah kode JavaScript menghasilkan atau menggunakan permintaan terhadap asal yang berbeda.
Misalnya, aplikasi web Anda berjalan pada port 8080 dan dengan menggunakan JavaScript Anda mencoba menggunakan layanan web RESTful dari port 9090. Dalam situasi seperti itu, Anda akan menghadapi masalah keamanan Berbagi Sumber Daya Lintas Asal di browser web Anda.
Dua persyaratan diperlukan untuk menangani masalah ini -
Layanan web yang tenang harus mendukung Cross-Origin Resource Sharing.
Aplikasi layanan web yang tenang harus mengizinkan akses API dari port 8080.
Dalam bab ini, kita akan mempelajari secara detail tentang Cara Mengaktifkan Permintaan Lintas Asal untuk aplikasi Layanan Web RESTful.
Aktifkan CORS dalam Metode Pengontrol
Kita perlu menyetel asal untuk layanan web RESTful dengan menggunakan @CrossOriginanotasi untuk metode pengontrol. Anotasi @CrossOrigin ini mendukung REST API tertentu, dan bukan untuk seluruh aplikasi.
@RequestMapping(value = "/products")
@CrossOrigin(origins = "http://localhost:8080")
public ResponseEntity<Object> getProduct() {
return null;
}
Konfigurasi CORS Global
Kita perlu mendefinisikan konfigurasi @Bean yang ditampilkan untuk mengatur dukungan konfigurasi CORS secara global ke aplikasi Spring Boot Anda.
@Bean
public WebMvcConfigurer corsConfigurer() {
return new WebMvcConfigurerAdapter() {
@Override
public void addCorsMappings(CorsRegistry registry) {
registry.addMapping("/products").allowedOrigins("http://localhost:9000");
}
};
}
Untuk kode untuk mengatur konfigurasi CORS secara global di aplikasi Spring Boot utama diberikan di bawah ini.
package com.tutorialspoint.demo;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.annotation.Bean;
import org.springframework.web.servlet.config.annotation.CorsRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter;
@SpringBootApplication
public class DemoApplication {
public static void main(String[] args) {
SpringApplication.run(DemoApplication.class, args);
}
@Bean
public WebMvcConfigurer corsConfigurer() {
return new WebMvcConfigurerAdapter() {
@Override
public void addCorsMappings(CorsRegistry registry) {
registry.addMapping("/products").allowedOrigins("http://localhost:8080");
}
};
}
}
Sekarang, Anda dapat membuat aplikasi web Spring Boot yang berjalan pada port 8080 dan aplikasi layanan web RESTful Anda yang dapat berjalan pada port 9090. Untuk detail lebih lanjut tentang implementasi tentang RESTful Web Service, Anda dapat merujuk ke bab berjudulConsuming RESTful Web Services dari tutorial ini.