解决前端开发环境的跨域问题

在我们进行项目开发时,想要和别的服务器进行通信,那肯定会遇到跨域问题,所谓跨域 就是因为同源策略的限制,导致不同源之间不能通信。所谓同源是指,域名,协议,端口相同。同源策略(Same origin policy)是一种约定,它是浏览器最核心也最基本的安全功能,如果缺少了同源策略,则浏览器的正常功能可能都会受到影响。可以说Web是构建在同源策略基础之上的,浏览器只是针对同源策略的一种实现。

解决跨域问题,通常有两种方式:第一:后台配置允许所有域访问或者允许指定域访问。第二:前端proxyTable配置代理。下面 我们来讲讲如何前端配置跨域,而且这只是在开发环境下的配置跨域,生产环境下还要配置Nginx代理服务。在vue项目的config文件下的index.js下中的proxyTable做如下配置(若我们调用的完整接口是:http://192.168.0.22:8080/Zloud/Controls/queryAllControls

proxyTable: {
      '/api': {
        target: 'http://192.168.0.22:8080',
        changeOrigin: true,
        pathRewrite: {
          '^/api': ''
        }    
      },
  // 倘若我们需要访问不同的服务器可像如下添加配置
      '/card': {
        target: 'http://api.pyun.com',
        changeOrigin: true,
        pathRewrite: {
          '^/card': ''
        }    
      }
    },

那我们调用接口就可以这样调用:

export const getLampMgmtInfoList = (params) => {
  return Axios.post('/api/ZCloud/Controls/queryAllControls', params).then(res => res.data)
}

 这样配置好后,就不会再出现关于禁止访问的跨域报错了。

代理成功之后你查看自己网络请求中的url:http://localhost:8010/api/Zloud/Controls/queryAllControls,说明你已经把请求代理到自己的代理服务器上了,说明配置成功了。

 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值