CORS错误-前后端交互跨域问题

文章讲述了浏览器的同源策略以及它如何导致跨域问题。跨域并不阻止请求,但浏览器会阻止返回数据。解决方案包括前端的代理设置或使用Koa-CORS插件,以及后端添加@CrossOrigin注解或配置全局拦截器来允许跨域请求。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

要解决跨域问题,首先要了解浏览器的同源策略
同源策略:著名的安全策略,URL有三个基本组成部分:协议+域名或ip+端口,三个必须完全相同称之为同源,不同源的称之为跨域

跨域并不会阻止请求的发出,也不会阻止请求的接受,
跨域是浏览器为了保护当前页面,你的请求得到了响应,
浏览器不会把响应的数据交给页面上的回调,
取而代之的是去提示你这是一个跨域数据。
提示就是一个报错提示,就像这样:
Access to XMLHttpRequest at 'http://localhost:8082/user/login'
from origin 'http://localhost:8080' has been blocked by 
CORS policy: No 'Access-Control-Allow-Origin'
 header is present on the requested resource.

背景:
本地分别启动前端、后端项目进行调试。
前端项目地址 http://localhost:8080
后端项目地址 http://localhost:8082
解决方式有多种,以下前后端方案任选一个即可

一、前端改造

两种方式:

1. vue.config.js文件增加代理设置
module.exports = {
  devServer:{
    proxy:{
      '/api':{//表示拦截以/api开头的请求路径
        target:'http://localhost:8082',
        changOrigin: true,//是否开启跨域
        pathRewrite:{
          '^/api':'' //重写api,把api变成空字符,因为我们真正请求的路径是没有api的
        }
      }
    }
  }
}

其它用到ip的地方替换为"/api"

2. 引入插件 “koa-cors

二、后端改造

两种方式:

  1. 方法上添加 @CrossOrigin 注解
    @PostMapping("login")
    @ResponseBody
    @CrossOrigin
    public String login(String name, String password) {
        System.out.println("name:" + name);
        if ("123".equals(name) && "123".equals(password)) {
            return "token123456";
        }
        return "登录失败";
    }
  1. 设置全局拦截器
@Configuration
@Slf4j
public class WebConfig implements WebMvcConfigurer {
    @Override
    public void addCorsMappings(CorsRegistry registry) {
        registry.addMapping("/**")
                .allowedOriginPatterns("*")
                .allowCredentials(true)
                .allowedHeaders("*")
                .allowedMethods("*")
                .maxAge(3600);

    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值