SpringBoot跨域问题的解决方法

这篇文章主要讲解了“SpringBoot跨域问题的解决方法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“SpringBoot跨域问题的解决方法”吧!

成都创新互联是一家网站设计公司,集创意、互联网应用、软件技术为一体的创意网站建设服务商,主营产品:成都响应式网站建设公司成都品牌网站建设网络营销推广。我们专注企业品牌在网站中的整体树立,网络互动的体验,以及在手机等移动端的优质呈现。成都网站设计、网站制作、移动互联产品、网络运营、VI设计、云产品.运维为核心业务。为用户提供一站式解决方案,我们深知市场的竞争激烈,认真对待每位客户,为客户提供赏析悦目的作品,网站的价值服务。

什么是跨域?

定义:浏览器从一个域名的网页取请求另一个域名下的东西。通俗点说,浏览器直接从A域访问B域中的资源是不被允许的,如果想要访问,就需要进行一步操作,这操作就叫“跨域”。例如,你从百度的页面,点击一个按钮,请求了新浪的一个接口,这就进行了跨域。不单单只有域名不同就是跨域,域名、端口、协议其一不同就是不同的域,请求资源需要跨域。

为什么要跨域?

为什么需要跨域,而不直接访问其他域下的资源呢?这是浏览器的限制,专业点说叫浏览器同源策略限制。主要是为了安全考虑。现在的安全框架,一般请求的时候header中不是都存个token嘛,你要是用这个token去正常访问A域下的东西是没问题的,然后又去访问了B域,结果阴差阳错的还带着这个token,那么B域,或者说B网站是不是就可以拿着你的token去A域下做点什么呢,这就相当危险了。所以浏览器加上了所谓的浏览器同源策略限制。但是为了我们真的需要从A域下访问B的资源(正常访问),就需要用到跨域,跨越这个限制了。

SpringBoot解决跨域问题

SpringBoot可以基于Cors解决跨域问题,Cors是一种机制,告诉我们的后台,哪边(origin )来的请求可以访问服务器的数据。全局配置

配置实例如下:

@Configurationpublic class CorsConfig implements WebMvcConfigurer {  @Override  public void addCorsMappings(CorsRegistry registry) {    registry.addMapping("/**")      .allowedOrigins("*")      .allowCredentials(true)      .allowedMethods("GET", "POST", "PUT", "DELETE", "OPTIONS")      .maxAge(3600);  }}

首先实现了WebMvcConfigurer 接口,WebMvcConfigurer 这个接口十分强大,里面还有很多可用的方法,在SpringBoot2.0里面可以解决WebMvcConfigurerAdapter曾经的部分任务。其中一个方法就是addCorsMappings(),是专门为开发人员解决跨域而诞生的接口。其中构造参数为CorsRegistry。

看下CorsRegistry源码,十分简单:

public class CorsRegistry {  private final List registrations = new ArrayList<>();  public CorsRegistration addMapping(String pathPattern) {   CorsRegistration registration = new CorsRegistration(pathPattern);   this.registrations.add(registration);   return registration;  }    protected Map getCorsConfigurations() {   Map configs = new LinkedHashMap<>(this.registrations.size());   for (CorsRegistration registration : this.registrations) {     configs.put(registration.getPathPattern(), registration.getCorsConfiguration());   }   return configs;  }}

可以看出CorsRegistry 有个属性registrations ,按道理可以根据不同的项目路径进行定制访问行为,但是我们示例直接将pathPattern 设置为 /**,也就是说已覆盖项目所有路径,只需要创建一个CorsRegistration就好。getCorsConfigurations(),这个方法是获取所有CorsConfiguration的Map集合,key值为传入路径pathPattern。

回到示例代码CorsConfig中,registry对象addMapping()增加完传入路径pathPattern之后,return了一个CorsRegistration对象,是进行更多的配置,看一下CorsRegistration的代码,看看我们能配些什么?

public class CorsRegistration {  //传入的路径  private final String pathPattern;  //配置信息实体类  private final CorsConfiguration config;  //构造方法  public CorsRegistration(String pathPattern) {   this.pathPattern = pathPattern;   //原生注释看到了一个 @CrossOrigin 这个注解,待会看看是什么   // Same implicit default values as the @CrossOrigin annotation + allows simple methods   this.config = new CorsConfiguration().applyPermitDefaultValues();  }  //允许哪些源网站访问,默认所有  public CorsRegistration allowedOrigins(String... origins) {   this.config.setAllowedOrigins(Arrays.asList(origins));   return this;  }  //允许何种方式访问,默认简单方式,即:GET,HEAD,POST  public CorsRegistration allowedMethods(String... methods) {   this.config.setAllowedMethods(Arrays.asList(methods));   return this;  }  //设置访问header,默认所有  public CorsRegistration allowedHeaders(String... headers) {   this.config.setAllowedHeaders(Arrays.asList(headers));   return this;  }  //设置response headers,默认没有(什么都不设置)  public CorsRegistration exposedHeaders(String... headers) {   this.config.setExposedHeaders(Arrays.asList(headers));   return this;  }  //是否浏览器应该发送credentials,例如cookies Access-Control-Allow-Credentials  public CorsRegistration allowCredentials(boolean allowCredentials) {   this.config.setAllowCredentials(allowCredentials);   return this;  }  //设置等待时间,默认1800秒  public CorsRegistration maxAge(long maxAge) {   this.config.setMaxAge(maxAge);   return this;  }  protected String getPathPattern() {   return this.pathPattern;  }  protected CorsConfiguration getCorsConfiguration() {   return this.config;  }}

局部配置

刚才遇到一个@CrossOrigin这个注解,看看它是干什么的?

@Target({ ElementType.METHOD, ElementType.TYPE })@Retention(RetentionPolicy.RUNTIME)@Documentedpublic @interface CrossOrigin {  /** @deprecated as of Spring 5.0, in favor of {@link CorsConfiguration#applyPermitDefaultValues} */  @Deprecated  String[] DEFAULT_ORIGINS = { "*" };  /** @deprecated as of Spring 5.0, in favor of {@link CorsConfiguration#applyPermitDefaultValues} */  @Deprecated  String[] DEFAULT_ALLOWED_HEADERS = { "*" };  /** @deprecated as of Spring 5.0, in favor of {@link CorsConfiguration#applyPermitDefaultValues} */  @Deprecated  boolean DEFAULT_ALLOW_CREDENTIALS = false;  /** @deprecated as of Spring 5.0, in favor of {@link CorsConfiguration#applyPermitDefaultValues} */  @Deprecated  long DEFAULT_MAX_AGE = 1800  /**  * Alias for {@link #origins}.  */  @AliasFor("origins")  String[] value() default {};  @AliasFor("value")  String[] origins() default {};  String[] allowedHeaders() default {};  String[] exposedHeaders() default {};  RequestMethod[] methods() default {};  String allowCredentials() default "";  long maxAge() default -1;}

这个注解可以作用于方法或者类上,实现局部跨域,你会发现除了设置路径(因为没必要了,都定位到局部了)其他的参数与全局类似。

小结

SpringBoot可以基于Cors解决跨域问题,可以设置全局跨域,也可以实现局部跨域,灵活配置方便使用。

感谢各位的阅读,以上就是“SpringBoot跨域问题的解决方法”的内容了,经过本文的学习后,相信大家对SpringBoot跨域问题的解决方法这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是创新互联,小编将为大家推送更多相关知识点的文章,欢迎关注!


文章标题:SpringBoot跨域问题的解决方法
文章出自:http://ybzwz.com/article/pohode.html