vue之解决跨域问题[通俗易懂]

vue之解决跨域问题[通俗易懂]同源策略:http协议、主机名、端口号都要相同。因为浏览器同源策略的影响,向后端服务器请求数据的时候,不能进行访问。可以采用代理服务器的方式,代理服务器:浏览器向一个相同同源策略的g代理服务器上请求资源,因为服务器之间没有同源策略,代理服务器就去找后端服务器请求资源,在返回给浏览器解决方法一:在根目录下新建vue.config.js文件,这里是js文件哈。module.exports={ lintOnSave:false,//取消格式化 devServer:{ proxy:

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

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

同源策略: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

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/192540.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 代码实现二叉树的三种遍历_遍历二叉树口诀

    代码实现二叉树的三种遍历_遍历二叉树口诀文章目录一、图示理解(图片是一位前辈所留,在此感谢)1、先序遍历2、中序遍历3、后序遍历4、层序遍历二、深入理解三种遍历让我们来理解一下绕着外围跑一整圈的真正含义是:遍历所有结点时,都先往左孩子走,再往右孩子走。下面做一个实例吧三、代码实现加以理解以下是C语言全部代码实现下面是同样的例子用c++实现,大家可以参考一下一、图示理解(图片是一位前辈所留,在此感谢)1、先序遍历先序遍历可以想象成,…

  • SQL server 查询语句「建议收藏」

    SQL server 查询语句「建议收藏」select*fromtest.dbo.users–普通条件查询whereid=1;模糊查询 select*fromtest.dbo.users whereusernamelike’%li%’;范围查询 select*fromtest.dbo.users –id在1~3之间的数据 whereidbetween1and3; select*fromtest.dbo.users –id在1~3以外的数据 where.

  • INFOBRIGHT的使用总结

    INFOBRIGHT的使用总结

  • 域名怎么与主机空间绑定的_域名绑定虚拟主机

    域名怎么与主机空间绑定的_域名绑定虚拟主机域名怎么与主机空间绑定2008-07-2623:41由于各种原因,我们有时候需要在一个IP地址上建立多个web站点,在IIS中,我们可能通过简单的设置达到这个目标。  在IIS中,每个Web站点都具有唯一的、由三个部分组成的标识,用来接收和响应请求:  1、IP地址  2、端口号  3、主机头名。  在IIS中,在一个IP地址上建立多个独

    2022年10月15日
  • mysql设置隔离级别_修改mysql事务隔离级别

    mysql设置隔离级别_修改mysql事务隔离级别引言开始我们的内容,相信大家一定遇到过下面的一个面试场景面试官:“讲讲mysql有几个事务隔离级别?”你:“读未提交,读已提交,可重复读,串行化四个!默认是可重复读”面试官:“为什么mysql选可重复读作为默认的隔离级别?”(你面露苦色,不知如何回答!)面试官:”你们项目中选了哪个隔离级别?为什么?”你:“当然是默认的可重复读,至于原因。。呃。。。”(然后你就可以回去等通知了!)为了避免上述尴尬的…

  • Nginx使用

    Nginx使用

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号