uni-app两种方法解决跨域问题【已验证】

第一种:在项目根目录下(即跟App.vue同级)建vue.config.js,这个文件会默认优先加载*【转载人未验证】*

module.exports = {
	devServer:{
		port:'8080',
		disableHostCheck:true,
		proxy:{
			'/dpc':{
				target:'http://XXXXX:9088',
				changeOrigin:true,
				pathRewrite:{
					'^/dpc': ''
				}
			}
		}
	}
}

第二种:在manifest.json的代码视图中 根节点中(即{}中),做如下声明*【转载人已验证,有改动】*

"h5": {
	"devServer": {
		"port": 8080,	//浏览器运行端口
		"disableHostCheck": true,
		"proxy": {
			"/dpc": {
				"target": "XXXXXX:9088",		//实际请求服务器地址*【转载人此处是:target:'http://XXXXX:9088',】*
				"changeOrigin": true,
				"secure": true,
				"pathRewrite": {
					"^/dpc": ""
				}
			}
		}
	}

最后在你统一的网络请求中做如下判断即可:

var BASE_URL = 'http:XXXXXX:9088';    //不是h5默认这个地址
// #ifdef H5
BASE_URL = '/dpc';    //H5下将地址修改为/dpc
// #endif
 
//附上网络请求的封装
export default (options)=>{
	uni.showLoading({
		title:'加载中...'
	})
	return new Promise((resolve,reject) =>{
		uni.request({
			url:BASE_URL + options.url,
			method:options.method || 'GET',
			data:options.data || {},
			success(res) {
				if(res){
					resolve(res.data)
				}
			},
			fail(err) {
				reject(err)
			},
			complete() {
				uni.hideLoading()
			}
		})
	})
}
  • 0
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值