Vue-cli配置代理服务器,解决跨域请求问题

vue.config.js配置文件中加上devServer配置项

proxy里面的’/demo’是进入代理服务器的标识,target要请求的跨域路径,pathRewrite是访问路径的时候将路径标识删除

module.exports = {
  pages: {
    index: {
      //入口
      entry: 'src/main.js',
    },
  },
	lintOnSave:false, //关闭语法检查
	//开启代理服务器(方式一)
	/* devServer: {
    proxy: 'http://localhost:5000'
  }, */
	//开启代理服务器(方式二)
	devServer: {
   	 proxy: {
      '/demo': {
        target: 'http://localhost:5001',
		pathRewrite:{'^/demo':''},
        // ws: true, //用于支持websocket
        // changeOrigin: true //用于控制请求头中的host值
      }
    }
  }
}

在需要访问跨域请求的ajax访问地址加上进入代理服务器的标识demo就能实现跨域请求了

methods: {
	getCars(){
		axios.get('http://localhost:8080/demo/cars').then(
			response => {
				console.log('请求成功了',response.data)
			},
			error => {
				console.log('请求失败了',error.message)
			})
		}
	},
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在使用Vue-cli进行开发时,我们常常会遇到跨域的问题。为了解决这个问题,我们可以使用vue.config.js文件进行代理设置。 首先,打开项目根目录下的vue.config.js文件。 其次,我们需要在该文件中添加一个devServer选项,来进行代理配置。具体代码如下: ``` module.exports = { devServer: { proxy: { '/api': { target: 'http://example.com', // 需要跨域的域名 changeOrigin: true, // 是否进行跨域 pathRewrite: { '^/api': '' // 将/api替换为空字符串 } } } } } ``` 其中,target指定了需要跨域请求的域名。changeOrigin设置为true表示开启跨域。pathRewrite用于重写请求地址,将/api替换为空字符串。 最后,保存文件并重新运行项目。此时,我们就成功地设置了跨域代理。 然而,有时候我们可能会遇到404错误。这通常是因为代理地址不正确,或者目标服务器无法处理正确的路由地址。 我们需要确保target的值和实际需要跨域请求的域名一致。另外,需要确保pathRewrite中的替换规则正确。 如果以上操作仍然无法解决问题,可以参考目标服务器的接口文档,确认请求地址是否正确。同时,可以使用开发工具的网络面板查看请求的详细信息,以便进行进一步的排查。 总结:使用vue-cli进行跨域代理时,可以通过配置vue.config.js文件来解决跨域问题。如果出现404错误,需要检查配置是否正确,并确认目标服务器是否能正确处理请求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值