当前位置:   article > 正文

前后端分离vue跨域,devServer配置proxy代理, post请求无法接收json格式参数报错400, Could not proxy request... ECONNRESET_devserver post

devserver post

1. 问题描述
先说下问题,项目后端是微型Python框架flask,前端是vue-element, 本地开发我配置的是proxy代理,代码如下:

devServer: {
    port: port,
    open: true,
    overlay: {
      warnings: false,
      errors: true
    },
    before: require('./mock/mock-server.js'),
    proxy: {
      // 本地使用代理  线上使用nginx
      '/dev-api/api/': {
        target: `http://192.168.1.171:5100`,
        changeOrigin: true,
        pathRewrite: {
          '/dev-api/api/': '/api/'
        }
      }
    }
  },
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19

下面post请求接口:
在这里插入图片描述
用Postman直接请求是没问题的,如下图:
在这里插入图片描述
控制台打印的日志:
在这里插入图片描述
但是不知道为啥页面上请求超时,报错400:

在这里插入图片描述在这里插入图片描述
后台无法接收到json格式参数,如下图:

在这里插入图片描述
报错信息:

Proxy error: Could not proxy request /api// from localhost:9525 to http://... (ECONNRESET)

2. 解决办法:

修改vue.config.js文件,改动代码如下:

devServer: {
    host: 'localhost',
    port: port,
    overlay: {
      warnings: false,
      errors: true
    },
    before: require('./mock/mock-server.js'),
    proxy: {
      // 本地使用代理  线上使用nginx
      '/dev-api/api': {
        target: `http://192.168.1.171:5100`,
        changeOrigin: true,
        onProxyReq:function (proxyReq, req, res, options) {
          if (req.body) {
            let bodyData = JSON.stringify(req.body);
            // incase if content-type is application/x-www-form-urlencoded -> we need to change to application/json
            proxyReq.setHeader('Content-Type','application/json');
            proxyReq.setHeader('Content-Length', Buffer.byteLength(bodyData));
            // stream the content
            proxyReq.write(bodyData);
          }
        },
        pathRewrite: {
          '^/dev-api/api': '/api'
        }
      }
    }
  },
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29

再次请求,成功~~
在这里插入图片描述

参考博客:nodejs中http-proxy使用小结

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/weixin_40725706/article/detail/232346
推荐阅读
相关标签
  

闽ICP备14008679号