springboot2.1跨域
时间: 2023-08-31 14:11:08 浏览: 108
在Spring Boot 2.1中实现跨域请求可以通过以下几种方式:
1. 使用注解 `@CrossOrigin`:在你的控制器类或方法上添加`@CrossOrigin`注解,允许指定的源访问该接口。例如:
```java
@RestController
public class MyController {
@CrossOrigin(origins = "http://example.com")
@GetMapping("/api/data")
public String getData() {
// 处理请求并返回数据
return "Data";
}
}
```
2. 在配置类中使用 `WebMvcConfigurer` 接口:创建一个配置类,并实现`WebMvcConfigurer`接口,在其中重写`addCorsMappings`方法来配置跨域。例如:
```java
@Configuration
public class CorsConfig implements WebMvcConfigurer {
@Override
public void addCorsMappings(CorsRegistry registry) {
registry.addMapping("/api/**")
.allowedOrigins("http://example.com")
.allowedMethods("GET", "POST")
.allowCredentials(false)
.maxAge(3600);
}
}
```
3. 使用过滤器:创建一个过滤器来处理跨域请求。例如:
```java
@Component
public class CorsFilter implements Filter {
@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
HttpServletResponse httpResponse = (HttpServletResponse) response;
httpRequest.setHeader("Access-Control-Allow-Origin", "http://example.com");
httpRequest.setHeader("Access-Control-Allow-Methods", "GET,POST");
httpRequest.setHeader("Access-Control-Allow-Credentials", "false");
httpRequest.setHeader("Access-Control-Max-Age", "3600");
chain.doFilter(request, response);
}
}
```
这些方法可以根据你的具体需求选择其中一种来实现跨域请求。记得将`http://example.com`替换为你允许访问的源地址。
阅读全文