vue-cli5 proxy反代查看真实路径

本文介绍了在 Vue CLI5 中配置 proxy 进行反代时如何查看真实路径。尽管设置 logLevel 为 'debug' 未生效,作者通过阅读源码发现可以手动在源码中添加调试语句。另外,他还提供了利用 onProxyReq 和 onProxyReqWs 回调函数手动获取和打印请求路径的方法,作为等待官方解决的临时方案。
摘要由CSDN通过智能技术生成

vue-cli5 proxy反代查看真实路径

一、proxy配置

1.基础配置

按照源码以及官方,配置logLevel为 ‘debug’,即可

devServer: {
    https: false,
    proxy: {
      '/container-api': {
        target: 'http://***.***.***.204:30080',
        pathRewrite: { '^/container-api': '' },
        changeOrigin: true,
        logLevel: 'debug'
      },
    }
  },

2.解决方式

但是我在配置之后并没有任何日志打印在控制台。不知道是vue-cli5需要配置专门的日志插件还是其他原因。我已经在github提出issues,不知道是否会有回应。
但是通过阅读源码发现,外面可以手动在源码中加入调试语句,不过并不推荐,仅作本地临时调试使用。
在这里插入图片描述
我们在node_modules/http-proxy-middleware/dist/http-proxy-middleware.js中的prepareProxyRequest方法中的this.logger.debug('[HPM] %s %s %s %s', req.method, originalPath, arrow, newProxyOptions.target);前面打印console即可。按道理源码中this.logger.debug方法应该要打印,但是它没有生效。所以我们手动打印就行了

二、手动实现

修改源码这种方式很不推荐,因为只能在自己本地使用,而且一旦更新包就需要重新修改,还是安心等待官方进行处理吧。
在这之前我们可以利用proxy的回调手动进行设置。

    proxy: {
      '/container-api': {
        target: 'http://***.***.***.204:30080',
        pathRewrite: {'^/container-api': ''},
        changeOrigin: true,
        logLevel: 'debug',
        onProxyReq: (proxyReq, req) => {
          // http请求
          console.log('[HPM] %s %s %s %s', req.method, req.originalUrl, '->', req.url);
        },
        onProxyReqWs(proxyReq, req, socket, options, head) {
          // websocket请求
          console.log('[HPM] %s %s %s %s', req.method, '-', req.url);
        }
      },
    }

利用onProxyReq和onProxyReqWs获取对应路径即可。具体打印方式各位可以自行调整,这里只是一个示例。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值