生产环境中 mybatis-plus默认不打印日志
mybatis-plus:
configuration:
#log-impl: org.apache.ibatis.logging.nologging.NoLoggingImpl#关闭日志
log-impl: org.apache.ibatis.logging.stdout.StdOutImpl #开启sql日志
mybatis-plus:
configuration:
#log-impl: org.apache.ibatis.logging.nologging.NoLoggingImpl#关闭日志
log-impl: org.apache.ibatis.logging.stdout.StdOutImpl #开启sql日志
达梦数据库的binlog日志存储满了
可能会导致系统无法启动,因为满了后无法插入数据,导致系统启动一直卡住
一、前言🔥
在使用MultipartFile类调用transferTo()方法时,报错了,如何解决,此文告诉你。
环境说明:springboot2.3.1.REALSE + mysql5.6 + jdk1.8
二、报错展示🔥
在使用MultipartFile类调用transferTo()方法时,却报错了。
如下是重点报错内容:
java.io.IOException: java.io.FileNotFoundException: C:\Users\86157\AppData\Local\Temp\tomcat.11159546904116402439.8889\work\Tomcat\localhost\review\.\template\question-img\admin\20220527101841.jpg (系统找不到指定的路径。)
如下是控制台报错完整截图:
三、报错排查🔥
不假思索的一看到这“系统找不到指定的路径”,肯定是路径问题呗,我以为是我传的路径地址不对,那我debug看看,看看到最后传入到transferTo()方法时的入参是啥。很明显,确实是这串相对地址啊。
![](https://ooolo.net/usr/uploads/2024/02/3107862054.png)
emmm,好吧,还是报错了,我刨根问底,debug进transferTo()方法里,然后看到它有执行 this.part.write(dest.getpath 方法,进入write()方法内部,到这里,我们看到了我们想要的答案!你们看到了么?
如下是write()源码:
@Override
public void write(String fileName) throws IOException {
File file = new File(fileName);
if (!file.isAbsolute()) {
file = new File(location, fileName);
}
try {
fileItem.write(file);
} catch (Exception e) {
throw new IOException(e);
}
}
这段方法非常明显,先是判断传入的参数是否是相对路径,如果是相对路径,它会自己给我们拼接一个父路径(location)! 所以你应该知道那个奇怪的路径是从哪里来的了吧!
好了,现在是知道了问题在哪了吧,罪魁祸首就是transferTo()参数,如果是相对路径的话,它会自己拼接一个父路径,因为指定的相对路径中拼接我自定义的路径已经变成了一个不会存在的路径,保存肯定是失败告终。但如果你传入的参数只是一个文件名,那应该就能保存成功。但是这样,取文件的时候,又会遇到问题了,你可能都不知道文件在哪里!所以最直观的解决方案就是,给定一个绝对路径,这样妥妥是不会有问题的。
四、解决方案🔥
所以综上,问题就在于你调用transferTo()方法,参数路径得定义一个绝对路径方可行。
接下来,为了验证我的观点是否正确,我给图片保存目录设置一个绝对路径。那我先这样,为了给大家看的更直观一点,我直接通过获取项目根路径然后再拼接自定义路径吧!
具体演示请看如下:
我是以postman测试上传了两张图片,然后如下是我debug第一次循环时的截图,大家可以看到,savePath地址这肯定是没问题的。因为我是通过System.getProperty("user.dir") 来获取的项目根目录,然后拼接自定义路径,如果路径不存在,我是有些自动创建目录。
![](https://ooolo.net/usr/uploads/2024/02/1262177626.png)
接下来,给你们最直观的验证,就是查看下该保存目录下是否已经上传了图片?
问题描述:
在使用MultipartFile.transferto准备保存上传文件的时候报错IO路径错误(IO路径不存在),但是我肯定我指定的路径是存在的
出现原因:
MultipartFile.transferto(file)该方法内参数需要的是绝对路径而不是相对路径,如果我们传入的是相对路径的话,那么该方法就会去tomcat内的webapp下去寻找该相对路径。这样肯定是找不到对应路径的,所以会出现该报错
解决方案:
选择传入绝对路径而不是相对路径
file类有获取绝对值的方法getCanonicalPath()
修改后的代码
@PostMapping("/upload")
public myResult upLoadFiles(MultipartFile[] files, HttpServletRequest request) throws IOException {
// 1.获取所有文件的文件名 分配文件路径
String parentPath = "uploadFiles";
File parent = new File(parentPath);
if (!parent.exists()){
parent.mkdir();
log.info("开始创建parent文件夹:{}",parent.getPath());
}
for (MultipartFile file : files){
String fileName = file.getOriginalFilename();
String new_FileName = parent.getCanonicalPath()+File.separator+fileName;
log.info(new_FileName);
try {
file.transferTo(new File(new_FileName));
log.info("文件{}上传成功!",new_FileName);
} catch (IOException e) {
throw new RuntimeException(e);
}
}
return new myResult().ok();
}