SpringMVC利用dropzone組件實(shí)現(xiàn)圖片上傳
操作步驟如下
一、dropzone導(dǎo)入
01.dropzone官網(wǎng)下載其插件壓縮包并復(fù)制項(xiàng)目;
02.將CSS和JS文件在HTML文件中引入;
//下面src中的地址根據(jù)自己文件地址進(jìn)行修改,不能之間copy,否則可能用不了!??! <link rel="stylesheet" href="/static/assets/plugins/dropzone/min/dropzone.min.css" rel="external nofollow" /> <link rel="stylesheet" href="/static/assets/plugins/dropzone/min/basic.min.css" rel="external nofollow" /> <script src="/static/assets/plugins/dropzone/min/dropzone.min.js"></script>
二、dropzone的使用
只需要一個(gè) div 元素,用 JavaScript 代碼啟用即可
HTML 結(jié)構(gòu)如下:
<div id="dropz" class="dropzone"></div>
JavaScript 啟用代碼如下:
<script>
var myDropzone = new Dropzone("#dropz", {
url: "/upload", //需要上傳的后臺(tái)接口地址
dictDefaultMessage: '拖動(dòng)文件至此或者點(diǎn)擊上傳', // 設(shè)置默認(rèn)的提示語句
paramName: "dropzFile", // 傳到后臺(tái)的參數(shù)名稱
init: function () {
this.on("success", function (file, data) {
// 上傳成功觸發(fā)的事件
});
}
});
</script>
前端工作做完后,后臺(tái)需要提供文件上傳支持,我們使用 Spring MVC 來接收上傳的文件
三、SpringMVC的處理
commons-fileupload jar包導(dǎo)入
01.如果使用Meaven倉(cāng)庫(kù),在其Pom.xml添加如下依賴。
<dependency> <groupId>commons-fileupload</groupId> <artifactId>commons-fileupload</artifactId> <version>1.3.2</version> </dependency>
如果未使用Meaven,百度commons-fileupload下載jar并復(fù)制到項(xiàng)目中。
配置 spring-mvc.xml
需要 Spring 注入 multipartResolver 實(shí)例,spring-mvc.xml 增加如下配置:
<!-- 上傳文件攔截,設(shè)置最大上傳文件大小 10M = 10*1024*1024(B) = 10485760 bytes --> <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"> <property name="maxUploadSize" value="10485760"/> </bean>
Controller類的代碼實(shí)現(xiàn)
@Controller
public class UploadController {
@ResponseBody
@RequestMapping(value = "upload", method = RequestMethod.POST)
public String upload(MultipartFile dropzFile, HttpServletRequest request) {
// 獲取上傳的原始文件名
String fileName = dropzFile.getOriginalFilename();
// 設(shè)置文件上傳路徑
String filePath = request.getSession().getServletContext().getRealPath("/static/upload");
// 獲取文件后綴
String fileSuffix = fileName.substring(fileName.lastIndexOf("."), fileName.length());
// 判斷并創(chuàng)建上傳用的文件夾
File file = new File(filePath);
if (!file.exists()) {
file.mkdir();
}
// 重新設(shè)置文件名為 UUID,以確保唯一
file = new File(filePath, UUID.randomUUID() + fileSuffix);
try {
// 寫入文件
dropzFile.transferTo(file);
} catch (IOException e) {
e.printStackTrace();
}
return "";
}
}
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
java定時(shí)任務(wù)Timer和TimerTask使用詳解
這篇文章主要為大家詳細(xì)介紹了java定時(shí)任務(wù)Timer和TimerTask使用方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-02-02
SpringBoot整合freemarker實(shí)現(xiàn)代碼生成器
這篇文章主要為大家詳細(xì)介紹了SpringBoot如何整合freemarker實(shí)現(xiàn)一個(gè)簡(jiǎn)單的代碼生成器,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下2023-03-03
java實(shí)現(xiàn)科學(xué)計(jì)算器的全過程與代碼
最近編寫了一個(gè)功能較全面的科學(xué)計(jì)算器,該計(jì)算器不僅能進(jìn)行加、減、乘、除等混合運(yùn)算,而且能計(jì)算sin、cos、tan、log等函數(shù)的值,還要具有清零、退格、求倒數(shù)、求相反數(shù)等功能,這篇文章主要給大家介紹了關(guān)于java實(shí)現(xiàn)科學(xué)計(jì)算器的相關(guān)資料,需要的朋友可以參考下2022-06-06
Java中PriorityQueue實(shí)現(xiàn)最小堆和最大堆的用法
很多時(shí)候都會(huì)遇到PriorityQueue,本文主要介紹了Java中PriorityQueue實(shí)現(xiàn)最小堆和最大堆的用法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-06-06
java redis 實(shí)現(xiàn)簡(jiǎn)單的用戶簽到功能
這篇文章主要介紹了java redis 實(shí)現(xiàn)簡(jiǎn)單的用戶簽到功能,幫助大家更好的理解和使用Java,感興趣的朋友可以了解下2020-12-12
使用Spring的ApplicationEvent實(shí)現(xiàn)本地事件驅(qū)動(dòng)的實(shí)現(xiàn)方法
本文介紹了如何使用Spring的ApplicationEvent實(shí)現(xiàn)本地事件驅(qū)動(dòng),通過自定義事件和監(jiān)聽器,實(shí)現(xiàn)模塊之間的松耦合,提升代碼的可維護(hù)性和擴(kuò)展性。同時(shí)還介紹了異步事件和事件傳遞的相關(guān)知識(shí)2023-04-04
實(shí)例講解Java編程中數(shù)組反射的使用方法
這篇文章主要介紹了Java編程中數(shù)組反射的使用方法,通過編寫數(shù)組反射工具類可以重用許多基礎(chǔ)代碼,減少對(duì)類型的判斷過程,需要的朋友可以參考下2016-04-04

