跨域问题解决办法之一:proxyTable

解决跨域问题

问题一:为什么会有跨域问题

浏览器的同源策略不允许跨域访问
同源策略:指协议,域名,端口相同.

问题二:解决思路有什么?

既然浏览器不能跨域访问,那么跨域使用后台服务访问吗?
可以!

问题三:怎么让后台服务访问代替浏览器访问

使用proxyTable解决

问题四:什么是proxyTable?

vue-cli提供的解决vue开发环境下跨域问题的方法
proxyTable的底层使用了http-proxymiddleware
( https://github.com/chimurai/http-proxy-middleware )
它是http代理中间件,依赖于node.js, 基本原理是用服务端代理解决浏览器跨域
在这里插入图片描述

cms跨域解决原理是什么?

1.访问页面http://localhost:11111/
2.页面请求http://localhost:11111/cms
由于url由http://localhost:33333/cms…改为"http://localhost:11111/cms",所以不会存在跨域问题
3、通过proxyTable由node服务器代理请求 http://localhost:33333/cms.
服务端不存在跨域问题
具体配置如下:
1.修改api方法中的url的定义
请求前加/api前缀

//public是对axios的工具类封装,定义了http请求方法 
import http from './../../../base/api/public'
let sysConfig = require('@/../config/sysConfig')
let apiUrl = sysConfig.xcApiUrlPre;
export const page_list = (page,size,params) => {
	return http.requestQuickGet(apiUrl+'/cms/page/list/'+page+'/'+size)
}

2.在config/index.js下配置proxyTable
让以/api/cms开头的请求全部代理请求http://localhost:33333

'/api/cms': {
	target: 'http://localhost:31001',
	pathRewrite: {
		'^/api': ''//实际请求去掉/api        
 }
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值