Java中如何实现跨域?

解决跨域问题的核心是服务器支持CORS,常见Java实现方式包括:1. 使用Filter添加CORS响应头,适用于所有Java Web项目;2. spring Boot中用@CrossOrigin注解在Controller或方法上启用跨域;3. 配置WebMvcConfigurer的addCorsMappings全局管理跨域规则,推荐生产环境使用;4. 通过nginx反向代理使前后端同源,规避跨域。选择方案需结合技术与部署结构,注意处理OPTIONS预检请求和凭证传递。

Java中如何实现跨域?

java开发中,跨域问题通常出现在前后端分离架构中,前端请求后端接口时由于浏览器的同源策略被阻止。解决跨域的核心是让服务器支持CORS(Cross-Origin Resource Sharing)。以下是几种常见的Java实现方式:

1. 使用Filter过滤器处理跨域

通过自定义Filter,在请求头中添加CORS相关字段,适用于所有Java Web项目(如servlet、Spring等)。

示例代码:

public class CorsFilter implements Filter {
    @Override
    public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain)
        throws IOException, ServletException {
        httpServletResponse response = (HttpServletResponse) res;
        response.setHeader(“access-Control-Allow-Origin”, “*”);
        response.setHeader(“Access-Control-Allow-Methods”, “GET, POST, PUT, delete, OPTIONS”);
        response.setHeader(“Access-Control-Max-Age”, “3600”);
        response.setHeader(“Access-Control-Allow-Headers”, “Content-Type, Authorization”);
        if (“OPTIONS”.equalsIgnoreCase(((HttpServletRequest) req).getMethod())) {
            response.setStatus(HttpServletResponse.SC_OK);
            return;
        }
        chain.doFilter(req, res);
    }
}

然后在web.xml中注册该Filter或使用@WebFilter注解启用。

2. spring boot中使用@CrossOrigin注解

如果项目基于Spring Boot,可以在Controller类或方法上直接使用@CrossOrigin注解开启跨域支持。

示例:

立即学习Java免费学习笔记(深入)”;

@RestController
@RequestMapping(“/api”)
@CrossOrigin(origins = “http://localhost:3000”)
public class UserController {
    @GetMapping(“/users”)
    public List getUsers() {
        return userService.findAll();
    }
}

也可以只加在某个方法上,控制更精细。

3. 配置全局CORS策略(推荐)

在Spring Boot中,推荐通过配置类统一管理跨域规则,避免每个接口重复添加注解。

示例配置:

Java中如何实现跨域?

奇域

奇域是一个专注于中式美学的国风AI绘画创作平台

Java中如何实现跨域?30

查看详情 Java中如何实现跨域?

@Configuration
@EnableWebMvc
public class WebConfig implements WebMvcConfigurer {
    @Override
    public void addCorsMappings(CorsRegistry registry) {
        registry.addMapping(“/api/**”)
            .allowedOriginPatterns(“*”)
            .allowedMethods(“GET”, “POST”, “PUT”, “DELETE”)
            .allowedHeaders(“*”)
            .allowCredentials(true);
    }
}

这种方式集中管理,便于维护,适合生产环境。

4. 使用Nginx反向代理(非Java层)

前端和后端统一由Nginx服务,前端请求通过代理转发到后端,规避跨域。

Nginx配置示例:

server {
    listen 80;
    server_name localhost;

    location / {
        root /usr/share/nginx/html;
        index index.html;
    }

    location /api/ {
        proxy_pass http://backend:8080/;
    }
}

这样前端访问/api时实际由Nginx转发,属于同源请求。

基本上就这些常用方式。选择哪种取决于你的技术和部署结构。Spring项目建议用全局CORS配置,简单可控。不复杂但容易忽略细节,比如预检请求(OPTIONS)处理和凭证支持(withCredentials)。

暂无评论

发送评论 编辑评论


				
上一篇
下一篇
text=ZqhQzanResources