uniapp开发 H5 解决跨域问题

浏览器控制台报错

Access to XMLHttpRequest at 'http://xxx.xxx.xxx.xx:8080/app/easypoi/importExcelFile' from origin 'http://localhost:8080' has been blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource.

问题分析:

这是常见的跨域请求问题,在前后端分离的项目中常见,前端项目中的请求路径直接用后台请求路径(例如:http://xxx.xxx.xxx.xx:8080/demo/getUser.do),但根据浏览器的网络请求规则,后台Server是不允许这样直接调用的(会被当黑客恶意攻击给拦截掉)。从而导致该跨域请求被拒绝。

第一步

设置 代理根域名
在这里插入图片描述

第二步 设置代理 proxy

代理方法一: manifest.json中设置

在这里插入图片描述

"h5": {
			"devServer" : {
			"https" : false,
			// "port":"9011", //端口号
			"proxy": {  
				"/host": {  // 接口请求中 从 /host 这里 进行代理
					target: 'http://XXX.XXX.XXX.XX:9011', //这里后台的地址模拟的;应该填写你们真实的后台接口
					"changeOrigin": true,  // 允许跨域  
					"secure": false,
					"pathRewrite": {
						"^/host": ""   // 重定向 为空
					}  
				}  
			}  
		},
	}

代理方法二: vue.config.js中设置

在devServer{}内加入代理
在这里插入图片描述

module.exports = {
	// 配置路径别名
	configureWebpack: {
		devServer: {
			// 调试时允许内网穿透,让外网的人访问到本地调试的H5页面
			disableHostCheck: true,
			// port: '9011', //端口号
			proxy: {
				'/host': { // 接口请求中 从 /host 这里 进行代理
					target: 'http://XXX.XXX.XXX.XX:9011', //这里后台的地址模拟的;应该填写你们真实的后台接口
					changeOrigin: true, // 允许跨域
					pathRewrite: {
						'^/host': '' // 重定向 为空
					} 
				}
			}
		}
	}
	// productionSourceMap: false,
}
  • 5
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

织_网

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值