博客
关于我
SpringBoot解决跨域问题
阅读量:378 次
发布时间:2019-03-05

本文共 1588 字,大约阅读时间需要 5 分钟。

方法一:使用@CrossOrigin注解局部跨域

在控制器(@Controller)上使用注解或者方法上使用注解允许跨域。

@RestController@CrossOrigin(allowCredentials="true")public class CorsTestController {           @RequestMapping("/test")    public String preUser(){           System.out.println("test");        return "test";    }}

这里的allowCredentials="true"的作用在于允许跨域请求时携带cookie,在需要使用到session需要开启该属性保持会话。其他的属性可查看该注解源码进行设置。

方法二:Web Config的方式全局跨域

@Configurationpublic class CORSWebMvcConfiguration extends WebMvcConfigurerAdapter {     @Override  public void addCorsMappings(CorsRegistry registry) {   	  registry.addMapping("*")	  .allowedOrigins("*").exposedHeaders("token")	  .allowedMethods("GET", "HEAD", "POST", "PUT", "PATCH", "DELETE", "OPTIONS", "TRACE");  }}

方法三:过滤器

package com.example.pahms.config;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration;import org.springframework.web.cors.CorsConfiguration;import org.springframework.web.cors.UrlBasedCorsConfigurationSource;import org.springframework.web.filter.CorsFilter;@Configurationpublic class GlobalCorsConfig {       @Bean    public CorsFilter corsFilter() {           CorsConfiguration config = new CorsConfiguration();        config.addAllowedOrigin("*");        config.setAllowCredentials(true);        config.addAllowedMethod("*");        config.addAllowedHeader("*");        config.addExposedHeader("token");        UrlBasedCorsConfigurationSource configSource = new UrlBasedCorsConfigurationSource();        configSource.registerCorsConfiguration("/**", config);        return new CorsFilter(configSource);    }}

转载地址:http://ctmg.baihongyu.com/

你可能感兴趣的文章
MySQL 调优/优化的 101 个建议!
查看>>
mysql 转义字符用法_MySql 转义字符的使用说明
查看>>
mysql 输入密码秒退
查看>>
mysql 递归查找父节点_MySQL递归查询树状表的子节点、父节点具体实现
查看>>
mysql 里对root及普通用户赋权及更改密码的一些命令
查看>>
Mysql 重置自增列的开始序号
查看>>
MySQL 错误
查看>>
MySQL 面试,必须掌握的 8 大核心点
查看>>
MySQL 高可用性之keepalived+mysql双主
查看>>
MySql-2019-4-21-复习
查看>>
mysql-connector-java各种版本下载地址
查看>>
mysql-group_concat
查看>>
MySQL-redo日志
查看>>
MySQL-【1】配置
查看>>
MySQL-【4】基本操作
查看>>
Mysql-丢失更新
查看>>
Mysql-事务阻塞
查看>>
Mysql-存储引擎
查看>>
mysql-开启慢查询&所有操作记录日志
查看>>
MySQL-数据目录
查看>>