vue之解决跨域问题

、、、、、、、、、、、仅对以前所学做复习记录使用、、、、、、、、、

同源策略:http协议、主机名、端口号都要相同。

因为浏览器同源策略的影响,向后端服务器请求数据的时候,不能进行访问。
可以采用代理服务器的方式,代理服务器:
在这里插入图片描述
浏览器向一个相同同源策略的代理服务器上请求资源,因为服务器之间没有同源策略,代理服务器就去找后端服务器请求资源,在返回给浏览器

解决方法一:

在根目录下新建vue.config.js文件,这里是js文件哈。

module.exports = {
	lintOnSave:false, // 取消格式化
	
	devServer:{
		proxy:"http://houduanserver:5000" // 请求数据的地址
	}
}

在这里插入图片描述
这个请求的时候,会先到public文件夹下查找资源,如果有的话就返回public文件夹下资源,如果没有就请求代理服务器资源。
这种方法只能请求一种代理

解决方法二:

module.exports = {
	lintOnSave:false, // 取消格式化
	
	devServer:{
	   open:true,  // 当启动时自动打开浏览器
		proxy:{
			// 匹配以所有/api开头的请求路径,名字随意
			'/api':{
				target:"http://houduanserver:5000",// 请求服务器地址
				
				ws:true, // 用于支持websocket 默认true
				
				changeOrigin:true , // 默认true
				// 设置为true时,后端服务器收到的是host名为:houduanserver:5000
				// 设置为true时,后端服务器收到的是host名为:houduanserver:8080
				
				pathRewrite:{ '^/api':“” },
				// 当后端服务器中没有以/api开头的路径时,以空字符代替				
			},		

	'/api2':{
				target:"http://houduanserver:5001",// 请求地址
				
				ws:true, // 用于支持websocket 默认true
				
				changeOrigin:true , // 默认true
				// 设置为true时,后端服务器收到的是host名为:houduanserver:5000
				// 设置为false时,后端服务器收到的是host名为:houduanserver:8080
				
				pathRewrite:{'^/api2':' '},
				// 当后端服务器中没有以/api开头的路径时,以空字符代替				
			}
		}
	}
}

在这里插入图片描述
api意思是只要以/api开头的就直接请求代理服务器再到后端服务器。不像方法一中那样,去请求public文件夹,在去请求代理到后端服务器。

在这里插入图片描述
pathRewrite是当浏览器通过请求/api/data到代理服务器,代理服务器再去请求后端服务器,然而后端服务器没有/api/data路径,只有/data路径,所以找不到/api只好为空

这种方法可以请求多种代理

在用axios请求资源时,一定要加上/api

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值