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

现象

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

分析问题

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

解决问题

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

事后分析

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

你可能感兴趣的:(springcloud,java,springboot,java,服务器,数据库,jvm,开发语言)