仅支持post请求javascript
<form action="/website/realAuthUpload.do" enctype="multipart/form-data" method="post"> <input type="file" name="file"> <input type="submit"> </form>
dropzone CDN https://www.bootcdn.cn/dropzone/css
<link href="https://cdn.bootcss.com/dropzone/5.5.1/min/basic.min.css" rel="stylesheet"> <link href="https://cdn.bootcss.com/dropzone/5.5.1/min/dropzone.min.css" rel="stylesheet"> <script src="https://cdn.bootcss.com/dropzone/5.5.1/min/dropzone.min.js"></script>
或者去官网下载(dist文件)html
它是轻量级的,不依赖于任何其余库(如jQuery),而且是高度可定制的。前端
只须要一个 div
元素,用 JavaScript 代码启用便可java
html结构web
<div id="dropz" class="dropzone"></div>
JavaScript 启用代码以下:spring
var myDropzone = new Dropzone("#dropz", { url: "/upload", dictDefaultMessage: '拖动文件至此或者点击上传', // 设置默认的提示语句 paramName: "dropzFile", // 传到后台的参数名称 init: function () { this.on("success", function (file, data) { // 上传成功触发的事件,若是须要获取data数据,后端必须返回一个标准的json数据。 }); } });
其中 url
是必须的值,指明文件上传提交到哪一个页面。其余的值都是可选的,若是使用默认值的话能够省略json
url
:最重要的参数,指明了文件提交到哪一个页面method
:默认为 post
,若是须要,能够改成 put
paramName
:至关于 <input>
元素的 name
属性,默认为 file
maxFilesize
:最大文件大小,单位是 MBmaxFiles
:默认为 null,能够指定为一个数值,限制最多文件数量addRemoveLinks
:默认 false。若是设为 true,则会给文件添加一个删除连接acceptedFiles
:指明容许上传的文件类型,格式是逗号分隔的 MIME type 或者扩展名。例如:image/*, application/pdf, .psd, .obj
uploadMultiple
:指明是否容许 Dropzone 一次提交多个文件。默认为 false。若是设为 true,则至关于 HTML 表单添加 multiple 属性headers
:若是设定,则会做为额外的 header 信息发送到服务器。例如:{"custom-header": "value"}
init
:一个函数,在 Dropzone 初始化的时候调用,能够用来添加本身的事件监听器forceFallback
:Fallback 是一种机制,当浏览器不支持此插件时,提供一个备选方案。默认为 false。若是设为 true,则强制 fallbackfallback
:一个函数,若是浏览器不支持此插件则调用dictDefaultMessage
:没有任何文件被添加的时候的提示文本dictFallbackMessage
:Fallback 状况下的提示文本dictInvalidInputType
:文件类型被拒绝时的提示文本dictFileTooBig
:文件大小过大时的提示文本dictCancelUpload
:取消上传连接的文本dictCancelUploadConfirmation
:取消上传确认信息的文本dictRemoveFile
:移除文件连接的文本dictMaxFilesExceeded
:超过最大文件数量的提示文本file
为第一个参数addedfile
:添加了一个文件时发生removedfile
:一个文件被移除时发生。你能够监听这个事件并手动从服务器删除这个文件uploadprogress
:上传时按必定间隔发生这个事件。第二个参数为一个整数,表示进度,从 0 到 100。第三个参数是一个整数,表示发送到服务器的字节数。当一个上传结束时,Dropzone 保证会把进度设为 100。注意:这个函数可能被以同一个进度调用屡次success
:文件成功上传以后发生,第二个参数为服务器响应complete
:当文件上传成功或失败以后发生canceled
:当文件在上传时被取消的时候发生maxfilesreached
:当文件数量达到最大时发生maxfilesexceeded
:当文件数量超过限制时发生file list
做为第一个参数(仅当 uploadMultiple
被设为 true
时才会发生)successmultiple
completemultiple
cancelmultiple
totaluploadprogress
:第一个参数为总上传进度,第二个参数为总字节数,第三个参数为总上传字节数。var myDropzone = new Dropzone("#dropz", { url: "/upload", // 文件提交地址 method: "post", // 也可用put paramName: "file", // 默认为file maxFiles: 1,// 一次性上传的文件数量上限 maxFilesize: 2, // 文件大小,单位:MB acceptedFiles: ".jpg,.gif,.png,.jpeg", // 上传的类型 addRemoveLinks: true, parallelUploads: 1,// 一次上传的文件数量 //previewsContainer:"#preview", // 上传图片的预览窗口 dictDefaultMessage: '拖动文件至此或者点击上传', dictMaxFilesExceeded: "您最多只能上传1个文件!", dictResponseError: '文件上传失败!', dictInvalidFileType: "文件类型只能是*.jpg,*.gif,*.png,*.jpeg。", dictFallbackMessage: "浏览器不受支持", dictFileTooBig: "文件过大上传文件最大支持.", dictRemoveLinks: "删除", dictCancelUpload: "取消", init: function () { this.on("addedfile", function (file) { // 上传文件时触发的事件 }); this.on("success", function (file, data) { // 上传成功触发的事件 }); this.on("error", function (file, data) { // 上传失败触发的事件 }); this.on("removedfile", function (file) { // 删除文件时触发的方法 }); } });
http://www.uploadify.com/bootstrap
Flash Version:须要浏览器安装flash插件后端
Html5 Version:须要收费
auto:是否当图片选中后,直接上传(默认是ture)
buttonClass:按钮的样式(能够本身直接设置)
buttonCursor:鼠标放到按钮上的样式
buttonImage :按钮的图片,能够将按钮的样式变成一个图片
buttonText:按钮的文字
debug:flash是不经过浏览器进行请求的,因此须要dubug须要单独的建立窗口debug
fileObjName :至关于<input type="file" name="xxx">中的xxx
fileSizeLimit:控制文件上传大小
fileTypeDesc:文件类型提示描述;
fileTypeExts:控制文件类型
formData:额外的上传的数据
height:按钮高度
width:宽度
multi:能够上传多个文件(默认是false)
overrideEvents:表示我须要覆盖你的那些事件,或者我不须要你的那些事件
swf:指向 uploadify 的文件
uploader 后台处理请求的url
<div> <div> <a href="javascript:;" id="uploadBtn1" >上传正面</a> </div> <!--为了图片回显 src是服务器图片的路径地址--> <img alt="" src="" class="uploadImg" id="uploadImg1"/> <!--为了显示图片的地址--> <input type="hidden" name="image1" id="uploadImage1"/> </div>
一、回显图片的目的是让用户能够在页面上能够看到本身上传的图片
二、页面上隐藏一个地址,是为了在提交表单,Controller处理表单能够拿到用户上传的图片的服务器地址。
//把上传身份证正面的a标签变成一个uploadify的组件 $("#uploadBtn1").uploadify({ buttonText: "身份证正面", fileObjName: "file", fileTypeDesc: "身份证正面图片", fileTypeExts: "*.gif; *.jpg; *.png", multi: false, swf: "static/js/plugins/uploadify/uploadify.swf", uploader: "/realAuthUpload.do", overrideEvents: ["onUploadSuccess", "onSelect"], onUploadSuccess: function (file, data) { $("#uploadImg1").attr("src", data); //上传图片成功后显示图片 $("#uploadImage1").val(data); //上传图片成功后将图片地址放到form表单中,等待和表单一块儿提交 } });
咱们可使用commons-fileupload:commons-fileupload包中的FileUtils来加快咱们处理上传文件
<dependency> <groupId>commons-fileupload</groupId> <artifactId>commons-fileupload</artifactId> <version>1.3.2</version> </dependency>
spring-mvc.xml
须要 Spring 注入 multipartResolver
实例,spring-mvc.xml
增长以下配置:
<!-- 上传文件拦截,设置最大上传文件大小 10M = 10*1024*1024(B) = 10485760 bytes --> <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"> <property name="maxUploadSize" value="10485760"/> </bean>
package com.funtl.my.shop.web.admin.web.controller; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; import org.springframework.web.bind.annotation.ResponseBody; import org.springframework.web.multipart.MultipartFile; import javax.servlet.http.HttpServletRequest; import java.io.File; import java.io.IOException; import java.util.HashMap; import java.util.Map; import java.util.UUID; /** * 文件上传控制器 * <p>Title: UploadController</p> * <p>Description: </p> * * @author Lusifer * @version 1.0.0 * @date 2018/6/27 0:42 */ @Controller public class UploadController { @ResponseBody @RequestMapping(value = "upload", method = RequestMethod.POST) public Map<String, Object> upload(MultipartFile dropzFile, HttpServletRequest request) { Map<String, Object> result = new HashMap<>(); // 获取上传的原始文件名 String fileName = dropzFile.getOriginalFilename(); // 设置文件上传路径 String filePath = request.getSession().getServletContext().getRealPath("/static/upload"); // 获取文件后缀 String fileSuffix = fileName.substring(fileName.lastIndexOf("."), fileName.length()); // 判断并建立上传用的文件夹 File file = new File(filePath); if (!file.exists()) { file.mkdir(); } // 从新设置文件名为 UUID,以确保惟一 file = new File(filePath, UUID.randomUUID() + fileSuffix); try { // 写入文件 dropzFile.transferTo(file); } catch (IOException e) { e.printStackTrace(); } // 返回 JSON 数据,这里只带入了文件名 result.put("fileName", file.getName()); return result; } }
@Autowired private ServletContext servletContext; /** * 千万不要加requiredLogin */ @ResponseBody @PostMapping("realAuthUpload") public String realAuthUpload(MultipartFile file) { // 先获得basepath String basePath = servletContext.getRealPath("/upload"); String fileName = UploadUtil.upload(file, basePath); return "/upload/" + fileName; }
UploadUtil
/** * 上传工具 * * @author Administrator */ public class UploadUtil { /** * 处理文件上传 * * @param basePath 存放文件的目录的绝对路径 servletContext.getRealPath("/upload") */ public static String upload(MultipartFile file, String basePath) { String orgFileName = file.getOriginalFilename(); //FilenameUtils.getExtension(orgFileName)获得文件的扩展名字 String fileName = UUID.randomUUID().toString() + "." + FilenameUtils.getExtension(orgFileName); try { File targetFile = new File(basePath, fileName); FileUtils.writeByteArrayToFile(targetFile, file.getBytes()); //把文件同步到公共文件夹 //File publicFile=new File(BidConst.PUBLIC_IMG_SHARE_PATH,fileName); //FileUtils.writeByteArrayToFile(publicFile, file.getBytes()); } catch (IOException e) { e.printStackTrace(); } return fileName; } }
@RequestMapping(value = "/fileupload",method = RequestMethod.POST) public String fileupload(MultipartFile file,HttpServletRequest httpServletRequest) throws IOException { //获取文件的名字 String originalFilename = file.getOriginalFilename(); InputStream inputStream = file.getInputStream(); String path = httpServletRequest.getSession().getServletContext().getRealPath("/")+originalFilename; FileOutputStream fileOutputStream = new FileOutputStream(path,true); int len=-1; byte[] bytes = new byte[1024]; while ((inputStream.read(bytes))!=-1){ fileOutputStream.write(bytes); } fileOutputStream.close(); inputStream.close(); return "login"; }