springMVC圖片上傳的處理方式詳解
本文實例為大家分享了springMVC圖片上傳的處理方式,供大家參考,具體內(nèi)容如下
首先需要依賴的jar包:
<dependency> <groupId>commons-io</groupId> <artifactId>commons-io</artifactId> <version>1.3.2</version> </dependency> <dependency> <groupId>commons-fileupload</groupId> <artifactId>commons-fileupload</artifactId> <version>1.2.1</version> </dependency>
頁面:
<a href="javascript:;" rel="external nofollow" class="a-upload"> <input class="" type="file" name="file" id="file" required="required">上傳 </a>
大家如果覺得默認的上傳文件的按鈕不好看,可以引入下面的css樣式:
.a-upload {
padding: 4px 10px;
height: 27px;
line-height: 27px;
position: relative;
cursor: pointer;
color: #888;
background: #fafafa;
border: 1px solid #ddd;
border-radius: 4px;
overflow: hidden;
}
.a-upload input {
position: absolute;
width: 100%;
right: 0;
top: 0;
opacity: 0;
filter: alpha(opacity=0);
cursor: pointer
}
.a-upload:hover {
color: #444;
background: #eee;
border-color: #ccc;
text-decoration: none
}
前端腳本:
$('#file').on('change', function () {
var $this = $(this);
var formData = new FormData();
formData.append('file', $('#file')[0].files[0]);
var fileName = $('#file')[0].files[0].name;
var fileType = fileName.substring(fileName.lastIndexOf('.') + 1);
var fileSize = $('#file')[0].files[0].size;
if (fileType != 'jpg' && fileType != 'png' && fileType != 'gif') {
alert("請上傳.jpg、.png、.gif格式的圖片!");
return;
}
if (fileSize > 300 * 1024) {
alert("請上傳大小小于300KB的圖片!");
return;
}
$.ajax({
url: '/admin/upload',
type: 'POST',
data: formData,
cache: false,
processData: false,
contentType: false
}).done(function (result) {
if (result != '') {
$this.closest('div').append('<div class="img-preview"><img src="' + result + '"/></div>');
} else {
alert("請上傳.jpg、.png、.gif格式的圖片!");
}
}).fail(function () {
alert("圖片上傳失敗!");
});
});
后端接收:
@RequestMapping(value = "admin/upload", method = RequestMethod.POST)
@ResponseBody
public String uploadFile(@RequestParam("file") MultipartFile file) {
try {
String filename = file.getOriginalFilename();
if (filename.endsWith("jpg") || filename.endsWith("png") || filename.endsWith("gif")) {
String prefix = filename.substring(filename.lastIndexOf("."));
String imgName = UUID.randomUUID().toString() + prefix;
String imgUri = writeToFileSystem(imgName, file.getBytes());
return imgUri;
}
} catch (Exception e) {
LOG.error("uploadFile failed:", e);
}
return null;
}
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
- SpringMVC圖片文件跨服務(wù)器上傳
- WebUploader客戶端批量上傳圖片 后臺使用springMVC
- webuploader+springmvc實現(xiàn)圖片上傳功能
- springMVC使用ajaxFailUpload上傳圖片的方法
- SpringMVC多個文件上傳及上傳后立即顯示圖片功能
- SpringMVC框架實現(xiàn)上傳圖片的示例代碼
- SpringMVC中MultipartFile上傳獲取圖片的寬度和高度詳解
- bootstrap fileinput組件整合Springmvc上傳圖片到本地磁盤
- SpringMvc MultipartFile實現(xiàn)圖片文件上傳示例
- SpringMVC框架實現(xiàn)圖片上傳與下載
相關(guān)文章
淺談MySQL中是如何實現(xiàn)事務(wù)提交和回滾的
本文主要介紹了MySQL中是如何實現(xiàn)事務(wù)提交和回滾的,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-02-02
Java SpringSecurity+JWT實現(xiàn)登錄認證
這篇文章主要介紹了Java SpringSecurity+JWT實現(xiàn)登錄認證,首先通過給需要登錄認證的模塊添加mall-security依賴展開介紹,感興趣的朋友可以參考一下2022-06-06
如何使用Resttemplate和Ribbon調(diào)用Eureka實現(xiàn)負載均衡
這篇文章主要介紹了如何使用Resttemplate和Ribbon調(diào)用Eureka實現(xiàn)負載均衡,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-03-03
關(guān)于JFormDesigner的安裝及破姐超詳細教程
JFormDesigner是一種先進的圖形用戶界面Swing?的設(shè)計工具(非開源),具有一個獨立的開發(fā)工具產(chǎn)品和基于不同開發(fā)工具如Eclipse、NetBeans等的開發(fā)插件,本文給大家介紹JFormDesigner安裝破解教程,感興趣的朋友一起看看吧2023-12-12
解決新版idea新建文件沒有XML和Resource Bundle文件問題
這篇文章主要介紹了解決新版idea新建文件沒有XML和Resource Bundle文件問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-07-07
springboot中mybatis多數(shù)據(jù)源動態(tài)切換實現(xiàn)
在開發(fā)中,動態(tài)數(shù)據(jù)源配置還是用的比較多的,比如在多數(shù)據(jù)源使用方面,又或者是在多個DB之間切換方面。這里給出一個動態(tài)數(shù)據(jù)源的配置方案,感興趣的可以了解一下2021-07-07

