【前后端跨域问题】

概要

前后端跨域问题同查是指在前后端分离项目中,浏览器请求后端接口时,由于没有通过同源检查,响应被浏览器弃之不用。

整体流程

pic01

  • 同源检查: 只要协议、主机、端口之一不同,就不同源,例如
    • http://localhost:7070/a 和 https://localhost:7070/b 不同源
  • 同源检查是浏览器的行为,而且只针对fetch、xhr请求
    • 如果是其它客户端,例如 java http client,postman,它们是不做同源检查的
    • 通过表单提交、浏览器直接输入 url 地址这些方式发送的请求,也不会做同源检查
  • 更多相关知识请参考

解决方案

1.添加响应头: 服务端在响应头添加 Access-Control-Allow-Origin:*

  • 注解方式:@CrossOrigin
import org.springframework.web.bind.annotation.CrossOrigin;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class MyController {

    @GetMapping("/my-endpoint")
    @CrossOrigin(origins = "http://example.com")
    public String myEndpoint() {
        return "Hello, world!";
    }
}
  • 配置类方式
@Configuration
public class GlobalCorsConfig {

  /**
   * 允许跨域调用的过滤器
   */
  @Bean
  public CorsFilter corsFilter() {
   CorsConfiguration config = new CorsConfiguration();
   //允许白名单域名进行跨域调用
   config.addAllowedOrigin("*");
   //允许跨越发送cookie
   config.setAllowCredentials(true);
   //放行全部原始头信息
   config.addAllowedHeader("*");
   //允许所有请求方法跨域调用
   config.addAllowedMethod("*");
   UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource();
   source.registerCorsConfiguration("/**", config);
   return new CorsFilter(source);
  }
 }

2.通过nginx代理跨域(开发中采用)

由于服务器之间访问没有跨域,浏览器通过访问nginx去访问跨域地址
nginx代理跨域
浏览器请求nginx提供的地址,统一由nginx根据配置对各种类型的请求进行转发

3.前端通过代理服务器自行代理转发解决

使用http-proxy-middleware中间件

小结

解决前后端跨域主要有三种方式:

1.服务端允许跨域,在响应头中添加Access-Control-Allow-Origin:*

2.通过nginx代理跨域。

3.前端通过代理服务器自行代理转发解决。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值