本文主要是介绍记录一次transferto遇到的问题java.io.FileNotFoundException:的发生原因,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
现象
有一个接口,上传文件,然后先对文件进行A处理,得到结果后保存到数据库,然后对文件进行B处理,开始的时候已经有业务A了,接受一个MultipartFile的参数,处理完保存数据库,现在需要添加一个新的功能。于是我也将MultipartFile作为参数传入,做业务处理,但是当执行到transferto的时候,日志中提示java.io.FileNotFoundException。
分析问题
- 开始的时候认为是文件的问题,或者说上传的文件没有被正确读取,于是debug源代码,发现文件的大小是有的,但是执行transferto报错,分析失败
- 因为是上传到本地,开始的时候认为是不是内存不足,查看磁盘后发现也不是这个问题。 然后是权限,是不是本地的磁盘没有写权限,后排除
- 尝试别的上传接口,可以正常执行,将其他代码复制到新的业务逻辑执行,还是失败。
- 开始的时候我使用的restTemplate这个框架来发送远程调用的,可能是一些莫名其妙的bug,或者说场景不适合,于是尝试其他框架,也是错误
解决问题
后对比发现正常执行的接口都是只对文件进行一次处理,包括原有的逻辑,我注释掉A逻辑,发现B逻辑可以正常执行。判断是多次读取数据,流中没有数据了。
事后分析
其实这个问题并不是很难发现,中间处理过程也是没想到这里的问题,当时也没有去看A逻辑的代码,导致的问题。只能说修改已有的代码还是需要慎重一点。
这篇关于记录一次transferto遇到的问题java.io.FileNotFoundException:的发生原因的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!