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

要解决跨域问题,首先要了解浏览器的同源策略
同源策略:著名的安全策略,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);

    }
}
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值