VUE 请求代理地址localhost报错[HPM] Error occurred while trying to proxy request

目录

前言

问题排查

网络联通性测试

[ping localhost](#ping localhost)

[ping 127.0.0.1](#ping 127.0.0.1)

问题结论

解决方案

[强制使用 IPv4](#强制使用 IPv4)

[修改localhost 为127.0.0.1](#修改localhost 为127.0.0.1)

[localhost 与 127.0.0.1 的区别](#localhost 与 127.0.0.1 的区别)


前言

今天前后端联调测试vue报错,[HPM] Error occurred while trying to proxy request /getSystemTime from 127.0.0.1 to http://localhost:8080/api/ (ETIMEDOUT) (https://nodejs.org/api/errors.html#errors_common_system_errors),意思是这个请求uri /getSystemTime 请求到服务地址 http://localhost:8080 超时报错了,但是后端服务是正常启动的,

问题排查

这个问题在于 (ETIMEDOUT)也就是请求超时,vue客户端和服务端网络握手没有成功。正常来说localhost作为回环地址:允许计算机与自身进行网络通信,而不需要经过物理网络接口(如网卡)。所以可以在本地运行一个 Web 服务器,然后通过客户端访问 http://localhost:8080 服务。

网络联通性测试

ping localhost

通过ping localhost命令进行测试发现返回 ::1 (IPv6)

ping 127.0.0.1

通过 ping 127.0.0.1命令进行测试发现返回了127.0.0.1

所以通过上面测试发现 localhost 是一个特殊的主机名,它指向当前计算机本身,对应的 IP 地址是 127.0.0.1 (IPv4)或 ::1(IPv6)。

问题结论

vue请求的后端服务只监听了 IPv4,而vue发送localhost的地址请求被解析为ipv6的回环地址,所以请求不通。即 localhost -> 连接到 ::1:8080 -> 连接失败,而使用 127.0.0.1 -> 连接到 127.0.0.1:8080 -> 连接成功。

解决方案

强制使用 IPv4

在 hosts 文件中添加配置(需要管理员权限)Windows位置: C:\Windows\System32\drivers\etc\hosts,

Linux/Mac位置: /etc/hosts。

配置如下所示

127.0.0.1 localhost

::1 localhost # 可以注释掉这行

修改localhost 为127.0.0.1

将vue代理请求更换成127.0.0.1即可。

javascript 复制代码
   proxyTable: {
      '/api': {
          //target: 'http://localhost:8080/api/',
          target: 'http://127.0.0.1:8080/api/',
          changeOrigin: true,
          pathRewrite: {
            '^/api': ''
          }
        }
    },

localhost 与 127.0.0.1 的区别

对比项 localhost 127.0.0.1
本质 主机名(域名) IPv4 地址
解析 需要 DNS 解析 直接指向本地
IPv6 可能解析为 ::1 固定 IPv4 地址
系统 hosts 可能被修改 固定不变
连接速度 稍慢(需解析) 直接连接
相关推荐
keep one's resolveY6 分钟前
SpringBoot实现重试机制的四种方案
java·spring boot·后端
天空属于哈夫克340 分钟前
企业微信API常见的错误和解决方案
java·数据库·企业微信
摇滚侠1 小时前
VMvare 虚拟机 Oracle19c 安装步骤,远程连接 Oracle19c,百度网盘安装包
java·oracle
梁萌1 小时前
idea报错找不到XX包的解决方法
java·intellij-idea·启动报错·缺少包
Agent产品评测局2 小时前
生产排期与MES/ERP系统打通,实操方法详解 —— 2026企业级智能体自动化选型与实战指南
java·运维·人工智能·ai·chatgpt·自动化
阿丰资源2 小时前
基于Spring Boot的电影城管理系统(直接运行)
java·spring boot·后端
呱牛do it2 小时前
企业级门户网站设计与实现:基于SpringBoot + Vue3的全栈解决方案(Day 8)
java
消失的旧时光-19433 小时前
Spring Boot 工程化进阶:统一返回 + 全局异常 + AOP 通用工具包
java·spring boot·后端·aop·自定义注解
NE_STOP3 小时前
Redis--发布订阅命令和Redis事务
java
PAC_3Dame3 小时前
记一次真实的线上OOM
java