怎么做仲博注册网站,专做和田玉的网站,广西住房和城乡建设厅培训中心官方网站,开发一款app软件需要学什么前后端分离项目的跨域问题及解决办法
一、跨域简述
1、问题描述
这里前端vue项目的端口号为9000#xff0c;后端springboot项目的端口号为8080
2、什么是跨域
当一个请求url的协议、域名、端口三者之间任意一个与当前页面url不同即为跨域
当前页面url被请求页面url是否…前后端分离项目的跨域问题及解决办法
一、跨域简述
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/httpshttp://www.demo.com/http://www.study.com/是主域名不同demo/studyhttp://www.demo.com/http://test.demo.com/是子域名不同www/testhttp://www.demo.com:8080/http://www.demo.com:8081/是端口号不同8080/8081
3、出现跨域问题的原因
跨域问题是出于浏览器的同源策略限制。同源策略Sameoriginpolicy是一种约定它是浏览器最核心也最基本的安全功能如果缺少了同源策略则浏览器的正常功能可能都会受到影响。可以说Web是构建在同源策略基础之上的浏览器只是针对同源策略的一种实现。同源策略会阻止一个域的javascript脚本和另外一个域的内容进行交互。所谓同源即指在同一个域就是两个页面具有相同的协议protocol主机host和端口号port。
二、解决办法
一在后端解决的方法
在Sprigboot 的controler层面解决的方式就是
在相对应的解决方法上面加上注解 CrossOrigin下面的解决方法是收集的没有去实验过。可以解决的可以在下面留言
1、第一种解决办法后端配置跨域spring boot设置方式
第一步在后端的WebMvcConfig配置类中进行配置
Configuration
public class WebMvcConfig implements WebMvcConfigurer {/*** 跨域配置* 前后端分离必须配置出现跨域之后前端无法访问后端接口* param registry*/Overridepublic 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