Java前后端分离开发之跨域问题

错误代码

Access to XMLHttpRequest at ‘http://localhost:9999/user/login’ from origin ‘http://localhost:8888’ has been blocked by CORS policy: Response to preflight request doesn’t pass access control check: No ‘Access-Control-Allow-Origin’ header is present on the requested resource.

问题说明

跨域问题,源自浏览器的一个同源策略。它是浏览器最核心也是最基本的安全功能,所有支持 JavaScript 的浏览器都会使用这个策略。在同源策略中,要求 域名、协议、端口 3部分都要相同。从错误代码可以看出是CORS所致

解决办法

@Configuration
public class CorsConfig {
    @Bean
    public CorsFilter corsFilter() {
        // 1.添加CORS配置信息
        CorsConfiguration config = new CorsConfiguration();
        // 1) 允许的域,不要写*,否则cookie就无法使用了,这里填写请求的前端服务器
        config.addAllowedOrigin("http://localhost:8888");
        // 2) 是否发送Cookie信息
        config.setAllowCredentials(true);
        // 3) 允许的请求方式
        config.addAllowedMethod("OPTIONS");
        config.addAllowedMethod("HEAD");
        config.addAllowedMethod("GET");
        config.addAllowedMethod("PUT");
        config.addAllowedMethod("POST");
        config.addAllowedMethod("DELETE");
        config.addAllowedMethod("PATCH");
        // 4)允许的头信息
        config.addAllowedHeader("*");
        // 2.添加映射路径,我们拦截一切请求
        UrlBasedCorsConfigurationSource configSource = new UrlBasedCorsConfigurationSource();
        configSource.registerCorsConfiguration("/**", config);
        // 3.返回新的CorsFilter.
        return new CorsFilter(configSource);
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java前后端分离是一种常见的架构模式,它将前端和后端的开发分离,使得两者可以独立开发、测试和部署。以下是实现Java前后端分离的一般步骤: 1. 定义接口:首先,前后端需要共同定义接口,即前后端交互的数据格式和接口规范。可以使用类似Swagger的工具来定义和生成接口文档。 2. 前端开发:前端开发人员使用HTML、CSS和JavaScript等技术开发用户界面,通过Ajax或其他方式调用后端接口获取数据。 3. 后端开发:后端开发人员使用Java等后端技术开发业务逻辑和数据处理部分,并提供RESTful API或其他方式的接口供前端调用。 4. 接口对接:前端通过调用后端提供的接口来获取数据或提交请求。可以使用类似Axios或Fetch等工具来发送HTTP请求。 5. 跨域处理:由于前后端分离时,前端和后端可能运行在不同的域名或端口下,需要处理跨域请求。可以在后端配置允许跨域访问的设置,或使用反向代理服务器如Nginx进行跨域代理。 6. 测试与调试:前后端可以独立进行测试和调试。前端可以使用类似Postman或浏览器插件来测试后端接口的返回数据,后端可以使用单元测试框架如JUnit来进行接口测试。 7. 部署与发布:前后端可以独立进行部署和发布。前端可以将静态资源(HTML、CSS、JavaScript等)部署到Web服务器上,后端可以将Java应用部署到应用服务器上。 通过Java前后端分离的架构模式,可以提高开发效率、降低耦合度,并且使得前后端团队可以并行开发,更好地实现功能需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值