记录一次transferto遇到的问题java.io.FileNotFoundException:的发生原因

处理文件上传接口时的FileNotFoundException问题及解决
文章讲述了在处理上传文件时遇到FileNotFoundException的问题,经过调试发现是由于多次读取文件流导致数据耗尽。作者通过对比和排除法,最终确定问题在于A逻辑的处理,并强调修改现有代码时需谨慎。

现象

有一个接口,上传文件,然后先对文件进行A处理,得到结果后保存到数据库,然后对文件进行B处理,开始的时候已经有业务A了,接受一个MultipartFile的参数,处理完保存数据库,现在需要添加一个新的功能。于是我也将MultipartFile作为参数传入,做业务处理,但是当执行到transferto的时候,日志中提示java.io.FileNotFoundException。

分析问题

  1. 开始的时候认为是文件的问题,或者说上传的文件没有被正确读取,于是debug源代码,发现文件的大小是有的,但是执行transferto报错,分析失败
  2. 因为是上传到本地,开始的时候认为是不是内存不足,查看磁盘后发现也不是这个问题。 然后是权限,是不是本地的磁盘没有写权限,后排除
  3. 尝试别的上传接口,可以正常执行,将其他代码复制到新的业务逻辑执行,还是失败。
  4. 开始的时候我使用的restTemplate这个框架来发送远程调用的,可能是一些莫名其妙的bug,或者说场景不适合,于是尝试其他框架,也是错误

解决问题

后对比发现正常执行的接口都是只对文件进行一次处理,包括原有的逻辑,我注释掉A逻辑,发现B逻辑可以正常执行。判断是多次读取数据,流中没有数据了。

事后分析

其实这个问题并不是很难发现,中间处理过程也是没想到这里的问题,当时也没有去看A逻辑的代码,导致的问题。只能说修改已有的代码还是需要慎重一点。

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值