最近在写一个私人项目,在发送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请求体是流式数据,如果在其他地方消费过,不做特殊处理的话,后面的应用就消费不到了!
再返回前端应用进行查看。
前端通过node转发到后端应用,思考了半天,觉得只有mock才会影响到request请求体,所以去mock-server.js中去查看。
果然,在mock中消费了requestBody,导致在node转发时,request请求体丢失。
EOFException根因分析
前端mock把requestBody给消费掉了,导致传到后端没有body,后端在解析的时候发现request请求头的content-length是59,就一直等待接收数据,与此同时,前端也在等待后端返回结果。1分钟后,前端等待超时,前端发EOF请求(具体为何会发EOF还需要进一步学习),后端收到以后,发现和预期的消息不一致,就报了EOF这个错误。