自由的代价是孤独丶

导航

Spring Boot 解决跨域问题的 3 种方案

跨域:

image



解决方法一:

// 弊端:每一个controller类上都来添加这样的一个接口影响开发效率、维护性较差
@RestController
@RequestMapping(value = "/admin/system/index")
@CrossOrigin(allowCredentials = "true" , originPatterns = "*" , allowedHeaders = "*") 
public class IndexController {

}

解决方法二:

// 添加一个配置类配置跨域请求
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.CorsRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
@Configuration
public class CorsConfig implements WebMvcConfigurer {
    @Override
    public void addCorsMappings(CorsRegistry registry) {
        registry.addMapping("/**")   // 添加路径规则
                .allowedOrigins("*")
                .allowedMethods("GET", "HEAD", "POST", "PUT", "DELETE", "OPTIONS")
                .allowCredentials(true)   // 是否允许在跨域的情况下传递Cookie
                .allowedOriginPatterns("*")           // 允许请求来源的域规则
                .maxAge(3600)
                .allowedHeaders("*");   // 允许所有的请求头
    }
}


解决方法二:

public class GoodsController {
    @CrossOrigin(origins = "http://localhost:4000")
    @GetMapping("goods-url")
    public Response queryGoodsWithGoodsUrl(@RequestParam String goodsUrl) throws Exception {}
}


解决办法三:

网关

posted on 2021-05-29 11:05   不将就鸭  阅读(263)  评论(0)    收藏  举报