SpringMVC 上传文件<8>

1.在spring配置文件中添加

  <!-- 不使用commons 上传包配置 -->
    <bean id="multipartResolver"
          class="org.springframework.web.multipart.commons.CommonsMultipartResolver">

        <property name="defaultEncoding" value="UTF-8" />
        <property name="maxUploadSize" value="5400000" />
        <property name="uploadTempDir" value="image" />
    </bean>
  1. Html5FileUploadController.java
package com.company.combine.controller;

import java.io.File;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;

import javax.servlet.http.HttpServletRequest;

import com.company.combine.model.Product;
import com.company.combine.model.UploadFile;
import org.apache.commons.logging.Log;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.validation.BindingResult;
import org.springframework.web.bind.annotation.ModelAttribute;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.multipart.MultipartFile;


@Controller
public class Html5FileUploadController {

    private static final Log logger = org.apache.commons.logging.LogFactory.getLog(Html5FileUploadController.class);

    @RequestMapping(value = "/html5")
    public String inputProduct(Model model) {
        System.out.println("----------inputProduct------------:");
        model.addAttribute("product", new Product());
        return "html5";
    }

    @RequestMapping(value = "/file_upload", method = RequestMethod.POST)
    public void saveFile(HttpServletRequest httpServletRequest, @ModelAttribute UploadFile uploadFile,
            BindingResult bindingResult, Model model)  {
        System.out.println("----------saveFile------------:");
        MultipartFile multipartFile = uploadFile.getMultipartFile();
        
        String fileName = multipartFile.getOriginalFilename();
//      String fileNames =fileName.substring(fileName.lastIndexOf("\\"));
        
        // File imageFile = new
        // File(httpServletRequest.getContextPath()+"/image",fileName);
        File imageFile = new File(httpServletRequest.getServletContext().getRealPath("/image"),fileName);

        String path = httpServletRequest.getServletContext().getRealPath("/image");
        if (!new File(path).exists()) {
            new File(path).mkdir();
        }
        System.out.println("fileName:"+fileName);
        System.out.println("multipartFile.getName():"+multipartFile.getName());
        System.out.println("path:"+path);
        System.out.println("imageFile.getAbsolutePath():"+imageFile.getAbsolutePath());
        
        try {
            multipartFile.transferTo(imageFile);
//          model.addAttribute("image", imageFile.getAbsolutePath().toString());
        } catch (IllegalStateException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        
    }
}

3.UploadFile.java

package com.company.combine.model;

import org.springframework.web.multipart.MultipartFile;

public class UploadFile {
    public MultipartFile getMultipartFile() {
        return multipartFile;
    }

    public void setMultipartFile(MultipartFile multipartFile) {
        this.multipartFile = multipartFile;
    }

    private MultipartFile multipartFile;
}

4.html5.jsp

<%@ page language="java" contentType="text/html; charset=utf-8"
    pageEncoding="GB2312"%>
<!DOCTYPE html >
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<script type="text/javascript">
    var totalFileLength,totalUploaded,fileCount,filesUploaded;
    
    function debug(s){
        var debug = document.getElementById('debug');
        if(debug){
            debug.innerHTML = debug.innerHTML+'</br>'+s;
        }
    }
    
    function onUploadComplete(e){
        totalUploaded += document.getElementById('files').files[filesUploaded].size;
        filesUploaded++;
        debug('complete'+filesUploaded+'of'+fileCount);
        debug('totalUploaded:'+totalUploaded);
        debug('filesUploaded:'+filesUploaded);
        if(filesUploaded < fileCount){
            uploadNext();
        }else{
            var bar = document.getElementById('bar');
            bar.style.width = '100%';
            bar.innerHTML = '100% complete';
            alert('Finished uploaded file(s))');
        }
    }
    
    function onFileSelect(e){
        var files = e.target.files;
        var output = [];
        fileCount = files.length;
        debug('fileCount:'+fileCount);
        totalFileLength = 0;
        
        for(var i=0;i<fileCount;i++){
            var file = files[i];
            output.push(file.name,'(',file.size,'bytes,',file.lastModifiedDate.toLocaleDateString(),')');
            output.push('<br/>');
            debug('add'+file.size);
            totalFileLength += file.size;
            document.getElementById('selectedFiles').innerHTML = output.join('');
            debug('totalFileLength:'+totalFileLength);
            document.getElementById('selectedFiles').innerHTML = output.join('');
            debug('totalFileLength:'+totalFileLength);
        }
    }
    function onUploadProgress(s){
        if(e.lengthComputable){
            var percentComplete = parseInt((e.loaded + totalUploaded)*100/totalFileLength);
            var bar = document.getElementById('bar');
            bar.style.width = percentComplete + '%';
            bar.innerHTML = percentComplete + '%complete';
        }else{
            debug('unable to complete');
        }
    }
    
    function onUploadFailed(e){
        alert("Error uploading file");
    }
    
    function uploadNext(){
        var xhr = new XMLHttpRequest();
        var fd = new FormData();
        var file = document.getElementById('files').files[filesUploaded];
        fd.append("multipartFile",file);
        xhr.upload.addEventListener("progress",onUploadProgress,false);
        xhr.addEventListener("load",onUploadComplete,false);
        xhr.addEventListener("error",onUploadFailed,false);
        xhr.open("post","file_upload");
        debug('uploading'+file.name);
        xhr.send(fd);
    }
    function startUpload(){
        totalUploaded = filesUploaded = 0;
        uploadNext();
    }
    
    window.onload = function(){
        document.getElementById('files').addEventListener('change',onFileSelect,false);
        document.getElementById('uploadedButton').addEventListener('click',startUpload,false);
    }
</script>
<title>登录</title>
</head>
<body>
<h1>Multiple file uploads with progress bar</h1>
<div id='progressBar' style='height:20px;border:2px solid green'></div>
<div id='bar' style='height:100%;background:#33dd33;width:0%'>
</div>

    <form >
        <input id="files"  type="file"  multiple="multiple"/><br>
        <output id='selectedFiles'></output>
        <input id="uploadedButton" type="button" value="Upload"/><br>
    </form>
    <div id='debug' style='height:100px;border:2px solid green;overflow:auto'>
    </div>
</body>
</html>
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,723评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,003评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,512评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,825评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,874评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,841评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,812评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,582评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,033评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,309评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,450评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,158评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,789评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,409评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,609评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,440评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,357评论 2 352

推荐阅读更多精彩内容