java.io.EOFException: Unexpected EOF read on the socket

项目:vue-element-admin

最近在写一个私人项目,在发送post请求时,遇到了这个坑爹的EOFException,花了差不多一个周末的时间才解决(其实是因为自己菜,不明白http相关原理),特此记录下,以备后续排查错误。

EOFException 的含义

Signals that an end of file or end of stream has been reached unexpectedly during input.
在输入过程中意外地到达文件结尾或流结束的信号

错误排查

springboot应用打印出debug级别日志(在排查问题时,可以尝试使用debug级别日志)发现:通过postman发送的请求,能够看到request请求的请求体;但通过前端应用发送的请求,没有request请求体。

而request请求体是流式数据,如果在其他地方消费过,不做特殊处理的话,后面的应用就消费不到了!

再返回前端应用进行查看。

 

image.png

 

前端通过node转发到后端应用,思考了半天,觉得只有mock才会影响到request请求体,所以去mock-server.js中去查看。

 

注意:注销后需要重启项目


果然,在mock中消费了requestBody,导致在node转发时,request请求体丢失。

EOFException根因分析

前端mock把requestBody给消费掉了,导致传到后端没有body,后端在解析的时候发现request请求头的content-length是59,就一直等待接收数据,与此同时,前端也在等待后端返回结果。1分钟后,前端等待超时,前端发EOF请求(具体为何会发EOF还需要进一步学习),后端收到以后,发现和预期的消息不一致,就报了EOF这个错误。

 

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值