form-data请求返回500(Could not parse multipart servlet request; nested exception is java.io.IOException)

form-data请求返回500(Could not parse multipart servlet request; nested exception is java.io.IOException)_第1张图片
问题描述:接口采用post请求,参数以表单形式提交,数据格式是application/x-www-form-urlencoded没有问题,数据格式用form-data时报错如下:

{
    "timestamp": 1571629285428,
    "status": 500,
    "error": "Internal Server Error",
    "exception": "org.springframework.web.multipart.MultipartException",
    "message": "Could not parse multipart servlet request; nested exception is java.io.IOException: The temporary upload location [/tmp/tomcat.887546452986925761.80/work/Tomcat/localhost/ROOT] is not valid",
    "path": "/api/sensitive/public/getRuleByScene"
}

**问题原因:**问题很明显,就是/tmp/tomcat.887546452986925761.80/work/Tomcat/localhost/ROOT这个目录找不到。网上查到:SpringBoot应用服务在启动(java -jar 命令启动服务)的时候,会在操作系统的/tmp目录下生成一个tomcat*的文件目录,上传的文件先要转换成临时文件保存在这个文件夹下面。
但是我这个请求不是上传文件,看来无论参数是否是文件,数据格式是form-data的post请求都需要tomcat的临时目录

解决方法:

  1. 手动创建这个目录
  2. 重启应用
  3. 在配置文件中指定tomcat的临时目录,这样就不怕系统自动清理tmp了(推荐使用)。
server.tomcat.basedir: /data/tomcat/tmp

你可能感兴趣的:(Java基础)