官术网_书友最值得收藏!

Enabling cross origin for microservices interactions

Browsers are generally restricted when client-side web applications running from one origin request data from another origin. Enabling cross origin access is generally termed as CORS (Cross Origin Resource Sharing).

This is particularly important when dealing with microservices, such as when the microservices run on separate domains, and the browser tries to access these microservices from one browser after another:

The preceding example showcases how to enable cross origin requests. With microservices, since each service runs with its own origin, it will easily get into the issue of a client-side web application, which consumes data from multiple origins. For instance, a scenario where a browser client accesses customers from the customer microservice, and order history from the order microservices is very common in microservices world.

Spring Boot provides a simple declarative approach for enabling cross origin requests.

The following code example shows how to use a microservice to enable cross origin:

    @RestController
class GreetingController{
@CrossOrigin
@RequestMapping("/")
Greet greet(){
return new Greet("Hello World!");
}
}

By default, all origins and headers are accepted. We can further customize the cross origin annotations by giving access to a specific origin as follows. The @CrossOrigin annotation enables a method or a class to accept cross origin requests:

    @CrossOrigin("http://mytrustedorigin.com")

Global CORS could be enabled by using the WebMvcConfigurer bean, and customizing the addCorsMappings (CorsRegistry registry) method.

主站蜘蛛池模板: 南京市| 常熟市| 阳曲县| 紫云| 呼伦贝尔市| 新龙县| 晋江市| 砀山县| 沅江市| 神农架林区| 司法| 东乡| 新晃| 元阳县| 乐山市| 威信县| 中山市| 凤阳县| 景东| 阳城县| 台北市| 永川市| 连江县| 靖边县| 崇义县| 天峻县| 兴安县| 游戏| 普定县| 呼和浩特市| 广西| 青浦区| 寿光市| 津南区| 拜泉县| 德钦县| 新泰市| 上蔡县| 敦煌市| 确山县| 南漳县|