首页 > Java > Java面试题 > 正文

Java中如何实现跨域?

幻夢星雲
发布: 2025-10-28 08:49:01
原创
392人浏览过
解决跨域问题的核心是服务器支持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中,推荐通过配置类统一管理跨域规则,避免每个接口重复添加注解。

示例配置:

奇域
奇域

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

奇域30
查看详情 奇域
@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)。

以上就是Java中如何实现跨域?的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号