dan*_*i77 4 java mysql ajax jquery spring-boot
我使用的是 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);
}
}
Run Code Online (Sandbox Code Playgroud)
我正在尝试将此文件上传到 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`);
Run Code Online (Sandbox Code Playgroud)
前端是一个带有 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');
}
});
Run Code Online (Sandbox Code Playgroud)
当我从 Internet Explorer 或 Microsoft Edge 上传文件时,该方法uis.getOriginalFilename()返回完整路径。
例如:c:\users\daniel\myfile.txt
如果我从 Google Chrome 上传文件,则 的值uis.getOriginalFileName()只是文件名。
例如:myfile.txt
我怎样才能只获取每个浏览器的名称而没有路径?
是否缺少一些 @Bean 来实现这一点?
谢谢。
使用 Apache Commons IO。它处理 Unix 或 Windows 格式的文件。
org.apache.commons.io.FilenameUtils.getName(multipartFile.getOriginalFilename());
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
16488 次 |
| 最近记录: |