前后端数据交互设计到的跨域问题
创始人
2025-01-10 19:03:49
0

前后端分离项目的跨域问题及解决办法

一、跨域简述
1、问题描述

这里前端vue项目的端口号为9000,后端springboot项目的端口号为8080
在这里插入图片描述

2、什么是跨域

当一个请求url的协议、域名、端口三者之间任意一个与当前页面url不同即为跨域

当前页面url被请求页面url是否跨域原因
http://www.demo.com/http://www.demo.com/index.html同源(协议、域名、端口号相同)
http://www.demo.com/https://www.demo.com/协议不同(http/https)
http://www.demo.com/http://www.study.com/主域名不同(demo/study)
http://www.demo.com/http://test.demo.com/子域名不同(www/test)
http://www.demo.com:8080/http://www.demo.com:8081/端口号不同(8080/8081)
3、出现跨域问题的原因

跨域问题是出于浏览器的同源策略限制。同源策略(Sameoriginpolicy)是一种约定,它是浏览器最核心也最基本的安全功能,如果缺少了同源策略,则浏览器的正常功能可能都会受到影响。可以说Web是构建在同源策略基础之上的,浏览器只是针对同源策略的一种实现。同源策略会阻止一个域的javascript脚本和另外一个域的内容进行交互。所谓同源(即指在同一个域)就是两个页面具有相同的协议(protocol),主机(host)和端口号(port)。

二、解决办法

一,在后端解决的方法:

在Sprigboot 的controler层面解决的方式就是 在相对应的解决方法上面加上注解  @CrossOrigin 

image-20240715103101828

(下面的解决方法是收集的,没有去实验过。可以解决的可以在下面留言)

1、第一种解决办法:后端配置跨域(spring boot设置方式)

第一步:在后端的WebMvcConfig配置类中进行配置

@Configuration public class WebMvcConfig implements WebMvcConfigurer {      /**      * 跨域配置      *       前后端分离必须配置,出现跨域之后前端无法访问后端接口      * @param registry      */     @Override     public void addCorsMappings(CorsRegistry registry) {         // 允许跨域访问资源定义: /rest/ 所有资源         registry.addMapping(GlobalConstant.REST_URL_PREFIX +"/**")                 // 只允许本地的指定端口访问 //                .allowedOrigins("http://localhost:8080"); //                // 允许发送Cookie                 .allowCredentials(true); //                // 允许所有方法 //                .allowedMethods("GET", "POST", "PUT", "DELETE", "HEAD");     } } 1234567891011121314151617181920 

第二步:在vue项目src目录下的http包中的config.js进行配置携带凭证(cookie)
在这里插入图片描述

注意:这里是因为我需要前端发送凭证(cookie)所以要配两步;如果不需要携带cookie,可以将第二步忽略,并且将第一步中的allowCredentials(true);注释掉。

2、第二种解决办法:前端配置代理(vue项目)

第一步:在config/index.js 文件,配置proxyTable
在这里插入图片描述

proxyTable: {       '/api': {         target: 'http://127.0.0.1:8080', //  请求后台的真实路径,这里是我本地启动的一个后台项目         changeOrigin: true, //         pathRewrite: {           '^/api': '' // 重写路径         }       },     }, 123456789 

第二步:在config/dev.env.js文件中加上一句
在这里插入图片描述

module.exports = merge(prodEnv, {   NODE_ENV: '"development"',   API: '"/api"' // 加入这一句 }) 1234 

因为这里我配的是全局路径,所以还要在global.js里配置全局路径
在这里插入图片描述

export const baseUrl = process.env.API 

全局路径
[外链图片转存中…(img-GLQCIvRt-1721010762474)]

export const baseUrl = process.env.API 

相关内容

热门资讯

第3分钟了解(aapoker讲... 第3分钟了解(aapoker讲解)外挂辅助下载(辅助挂)科技教程(2026已更新)(哔哩哔哩);aa...
第七分钟熟悉!wepoker辅... 第七分钟熟悉!wepoker辅助插件功能,德普之星辅助工具如何打开,总结教程(有挂秘籍)-哔哩哔哩1...
4阶段了解!兴动互娱辅助器,w... 4阶段了解!兴动互娱辅助器,wepoker亲友圈有用吗,教你攻略(有挂详情)1、玩家可以在兴动互娱辅...
第7分钟了解“哈灵小程序脚本”... 第7分钟了解“哈灵小程序脚本”详细透视开挂辅助安装-哔哩哔哩;大家肯定在之前哈灵小程序脚本或者哈灵小...
八分钟了解(钱柜手游)外挂辅助... 八分钟了解(钱柜手游)外挂辅助挂(透视)详细教程(2020已更新)(哔哩哔哩);亲真的是有正版授权,...
七分钟透视!aapoker辅助... 七分钟透视!aapoker辅助工具免费下载,wepoker透视方法,插件教程(有挂方式)-哔哩哔哩1...
第5些了解!仙神互娱辅助,智星... 第5些了解!仙神互娱辅助,智星菠萝辅助怎么买,2025新版(有挂头条)该软件可以轻松地帮助玩家将仙神...
8分钟了解“微信雀神小程序插件... 8分钟了解“微信雀神小程序插件”详细透视开挂辅助攻略-哔哩哔哩;是一款可以让一直输的玩家,快速成为一...
第6分钟了解(pokerwor... 第6分钟了解(pokerworld软件)外挂辅助软件(透视)详细教程(2024已更新)(哔哩哔哩)是...
第5分钟黑科技!aapoker... 第5分钟黑科技!aapoker破解侠是真的吗,智星菠萝可以辅助吗,教你攻略(有挂解密)-哔哩哔哩第5...