2018-01-17 14:10:40 +08:00
|
|
|
|
package cn.keking.web.controller;
|
|
|
|
|
|
2019-04-16 21:09:32 +08:00
|
|
|
|
import cn.keking.config.ConfigConstants;
|
2018-01-17 14:10:40 +08:00
|
|
|
|
import com.fasterxml.jackson.core.JsonProcessingException;
|
|
|
|
|
import com.fasterxml.jackson.databind.ObjectMapper;
|
2020-12-26 01:52:52 +08:00
|
|
|
|
|
2018-01-19 14:51:18 +08:00
|
|
|
|
import cn.keking.model.ReturnResponse;
|
2020-05-14 10:04:09 +08:00
|
|
|
|
import org.slf4j.Logger;
|
|
|
|
|
import org.slf4j.LoggerFactory;
|
2020-05-15 18:09:19 +08:00
|
|
|
|
import org.springframework.util.StreamUtils;
|
2018-01-17 14:10:40 +08:00
|
|
|
|
import org.springframework.web.bind.annotation.RequestMapping;
|
|
|
|
|
import org.springframework.web.bind.annotation.RequestMethod;
|
|
|
|
|
import org.springframework.web.bind.annotation.RequestParam;
|
|
|
|
|
import org.springframework.web.bind.annotation.RestController;
|
|
|
|
|
import org.springframework.web.multipart.MultipartFile;
|
|
|
|
|
|
|
|
|
|
import java.io.*;
|
2020-12-26 01:52:52 +08:00
|
|
|
|
import java.util.*;
|
2018-01-17 14:10:40 +08:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
*
|
|
|
|
|
* @author yudian-it
|
|
|
|
|
* @date 2017/12/1
|
|
|
|
|
*/
|
|
|
|
|
@RestController
|
|
|
|
|
public class FileController {
|
2020-05-14 10:04:09 +08:00
|
|
|
|
|
|
|
|
|
private final Logger logger = LoggerFactory.getLogger(FileController.class);
|
|
|
|
|
|
2020-05-15 18:09:19 +08:00
|
|
|
|
private final String fileDir = ConfigConstants.getFileDir();
|
|
|
|
|
|
|
|
|
|
private final String demoDir = "demo";
|
|
|
|
|
|
|
|
|
|
private final String demoPath = demoDir + File.separator;
|
2018-01-17 14:10:40 +08:00
|
|
|
|
|
|
|
|
|
@RequestMapping(value = "fileUpload", method = RequestMethod.POST)
|
2020-05-14 10:04:09 +08:00
|
|
|
|
public String fileUpload(@RequestParam("file") MultipartFile file) throws JsonProcessingException {
|
2019-07-30 10:02:36 +08:00
|
|
|
|
// 获取文件名
|
2018-01-17 14:10:40 +08:00
|
|
|
|
String fileName = file.getOriginalFilename();
|
2019-07-30 10:02:36 +08:00
|
|
|
|
//判断是否为IE浏览器的文件名,IE浏览器下文件名会带有盘符信息
|
|
|
|
|
// Check for Unix-style path
|
|
|
|
|
int unixSep = fileName.lastIndexOf('/');
|
|
|
|
|
// Check for Windows-style path
|
|
|
|
|
int winSep = fileName.lastIndexOf('\\');
|
|
|
|
|
// Cut off at latest possible point
|
2020-05-15 18:09:19 +08:00
|
|
|
|
int pos = (Math.max(winSep, unixSep));
|
2019-07-30 10:02:36 +08:00
|
|
|
|
if (pos != -1) {
|
|
|
|
|
fileName = fileName.substring(pos + 1);
|
|
|
|
|
}
|
2020-05-14 10:04:09 +08:00
|
|
|
|
// 判断是否存在同名文件
|
|
|
|
|
if (existsFile(fileName)) {
|
|
|
|
|
return new ObjectMapper().writeValueAsString(new ReturnResponse<String>(1, "存在同名文件,请先删除原有文件再次上传", null));
|
2018-01-17 14:10:40 +08:00
|
|
|
|
}
|
|
|
|
|
File outFile = new File(fileDir + demoPath);
|
|
|
|
|
if (!outFile.exists()) {
|
|
|
|
|
outFile.mkdirs();
|
|
|
|
|
}
|
2020-05-18 09:46:52 +08:00
|
|
|
|
logger.info("上传文件:{}", fileDir + demoPath + fileName);
|
2020-05-15 18:09:19 +08:00
|
|
|
|
try(InputStream in = file.getInputStream(); OutputStream out = new FileOutputStream(fileDir + demoPath + fileName)) {
|
|
|
|
|
StreamUtils.copy(in, out);
|
2018-01-17 14:10:40 +08:00
|
|
|
|
return new ObjectMapper().writeValueAsString(new ReturnResponse<String>(0, "SUCCESS", null));
|
|
|
|
|
} catch (IOException e) {
|
2020-05-14 10:04:09 +08:00
|
|
|
|
logger.error("文件上传失败", e);
|
2018-01-17 14:10:40 +08:00
|
|
|
|
return new ObjectMapper().writeValueAsString(new ReturnResponse<String>(1, "FAILURE", null));
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@RequestMapping(value = "deleteFile", method = RequestMethod.GET)
|
|
|
|
|
public String deleteFile(String fileName) throws JsonProcessingException {
|
|
|
|
|
if (fileName.contains("/")) {
|
|
|
|
|
fileName = fileName.substring(fileName.lastIndexOf("/") + 1);
|
|
|
|
|
}
|
|
|
|
|
File file = new File(fileDir + demoPath + fileName);
|
2020-05-14 10:04:09 +08:00
|
|
|
|
logger.info("删除文件:{}", file.getAbsolutePath());
|
2018-01-17 14:10:40 +08:00
|
|
|
|
if (file.exists()) {
|
|
|
|
|
file.delete();
|
|
|
|
|
}
|
|
|
|
|
return new ObjectMapper().writeValueAsString(new ReturnResponse<String>(0, "SUCCESS", null));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@RequestMapping(value = "listFiles", method = RequestMethod.GET)
|
|
|
|
|
public String getFiles() throws JsonProcessingException {
|
2020-12-26 01:52:52 +08:00
|
|
|
|
List<Map<String, String>> list = new ArrayList<>();
|
2018-01-17 14:10:40 +08:00
|
|
|
|
File file = new File(fileDir + demoPath);
|
|
|
|
|
if (file.exists()) {
|
2020-12-26 01:52:52 +08:00
|
|
|
|
Arrays.stream(Objects.requireNonNull(file.listFiles())).forEach(file1 -> {
|
|
|
|
|
Map<String, String> fileName = new HashMap();
|
|
|
|
|
fileName.put("fileName", demoDir + "/" + file1.getName());
|
|
|
|
|
list.add(fileName);
|
|
|
|
|
});
|
2018-01-17 14:10:40 +08:00
|
|
|
|
}
|
|
|
|
|
return new ObjectMapper().writeValueAsString(list);
|
|
|
|
|
}
|
|
|
|
|
|
2020-05-14 10:04:09 +08:00
|
|
|
|
private boolean existsFile(String fileName) {
|
|
|
|
|
File file = new File(fileDir + demoPath + fileName);
|
2020-05-15 18:09:19 +08:00
|
|
|
|
return file.exists();
|
2018-01-17 14:10:40 +08:00
|
|
|
|
}
|
|
|
|
|
}
|