我正在使用 spring boot 1.5.7-RELEASE 版本,我正在使用以下方法上传文件:
@Autowired private MyService mySerice;
@RequestMapping(value = "/uploadFile", method = { RequestMethod.POST }, produces = { MediaType.MULTIPART_FORM_DATA_VALUE,
MediaType.APPLICATION_FORM_URLENCODED_VALUE, MediaType.APPLICATION_JSON_VALUE })
public void upload(@RequestParam("file") MultipartFile uis, @RequestParam("user_id") String userId) {
MyFile myFile = new MyFile();
if (!uis.isEmpty()) {
myFile.setFile(uis.getBytes());
myFile.setName(uis.getOriginalFilename());
myFile.setUserId(userId);
myService.upload(myFile);
}
}
我正在尝试将此文件上传到 MySQL 中的此表:
CREATE TABLE `file_user` (
`id` int(5) UNSIGNED NOT NULL,
`user_id` bigint(20) UNSIGNED NOT NULL,
`file` mediumblob NOT NULL,
`name` varchar(50) COLLATE utf8mb4_unicode_ci NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
ALTER TABLE `file_user` ADD PRIMARY KEY (`id`);
前端是一个带有 Ajax 的简单表单 HTML。
var fileInput = $("#file_form_post")[0].files[0];
var data = new FormData();
data.append("file", fileInput);
data.append("user_id", $("#txt_uid").val());
$.ajax({
url: 'mypage.com:9002/uploadFile',
type: 'POST',
data: data,
cache: false,
contentType: false,
processData: false,
headers: {Accept: "application/json"},
success: function (r) {
alert('Upload OK');
},
error: function (request, status, error) {
alert('Upload error');
}
});
当我从 Internet Explorer 或 Microsoft Edge 上传文件时,该方法uis.getOriginalFilename()
返回完整路径。
例如:c:\users\daniel\myfile.txt
如果我从 Google Chrome 上传文件,则 valueuis.getOriginalFileName()
只是文件的名称。
例如:myfile.txt
我怎么能只获得名称而没有每个浏览器的路径?
是否缺少一些@Bean 来获得它?
javaLover 的建议不是一个好方法,因为它依赖于平台。例如,如果您的应用程序在 Linux 上运行并且您从 Windows 上传文件,Path.getFileName()
则无法识别 Windows 用作名称分隔符的反斜杠,并且您将再次获得完整路径而不仅仅是文件名。这就是为什么最好手动进行,例如
String fileName = uis.getOriginalFilename();
int startIndex = fileName.replaceAll("\\\\", "/").lastIndexOf("/");
fileName = fileName.substring(startIndex + 1);
myFile.setName(fileName);
这里我们首先将反斜杠替换为正斜杠,只关心一种风格的分隔符,然后找到最后一个分隔符在哪里。接下来,我们从找到的索引中删除字符串加上一,以摆脱斜线本身。即使getOriginalFilename()
只返回不带路径的文件名,此代码也将起作用,因为startIndex
将为 -1 并且生成的substring(0)
调用不会有任何效果。
使用 apache 公共 IO。它处理 Unix 或 Windows 格式的文件。
org.apache.commons.io.FilenameUtils.getName(multipartFile.getOriginalFilename());
以这种方式修改 Java 代码中的以下行:
myFile.setName(java.nio.file.Paths.get(uis.getOriginalFilename()).getFileName());`