springboot添加跨域
时间: 2024-01-06 21:25:17 浏览: 90
springboot 跨域请求
5星 · 资源好评率100%
在Spring Boot中添加跨域支持有几种常见的方法:
1. 使用注解@CrossOrigin:可以在Controller类或方法上使用@CrossOrigin注解来允许特定的域名或所有域名进行跨域访问。例如:
```java
@RestController
@CrossOrigin(origins = "http://example.com")
public class MyController {
// ...
}
```
这样,只有来自"http://example.com"域名的请求才能跨域访问该Controller。
2. 使用WebMvcConfigurer:可以通过实现WebMvcConfigurer接口来配置全局的跨域支持。例如:
```java
@Configuration
public class WebConfig implements WebMvcConfigurer {
@Override
public void addCorsMappings(CorsRegistry registry) {
registry.addMapping("/**")
.allowedOrigins("http://example.com")
.allowedMethods("GET", "POST", "PUT", "DELETE")
.allowedHeaders("*")
.allowCredentials(true);
}
}
```
这样,所有的请求都可以跨域访问,并且只允许来自"http://example.com"域名的请求。
3. 使用Filter:可以通过编写一个Filter来处理跨域请求。例如:
```java
@Component
public class CorsFilter implements Filter {
@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
HttpServletResponse httpResponse = (HttpServletResponse) response;
httpResponse.setHeader("Access-Control-Allow-Origin", "http://example.com");
httpResponse.setHeader("Access-Control-Allow-Methods", "GET, POST, PUT, DELETE");
httpResponse.setHeader("Access-Control-Allow-Headers", "*");
httpResponse.setHeader("Access-Control-Allow-Credentials", "true");
chain.doFilter(request, response);
}
}
```
这样,所有的请求都可以跨域访问,并且只允许来自"http://example.com"域名的请求。
阅读全文