<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    春風博客

    春天里,百花香...

    導航

    <2008年4月>
    303112345
    6789101112
    13141516171819
    20212223242526
    27282930123
    45678910

    統計

    公告

    MAIL: junglesong@gmail.com
    MSN: junglesong_5@hotmail.com

    Locations of visitors to this page

    常用鏈接

    留言簿(11)

    隨筆分類(224)

    隨筆檔案(126)

    個人軟件下載

    我的其它博客

    我的鄰居們

    最新隨筆

    搜索

    積分與排名

    最新評論

    閱讀排行榜

    評論排行榜

    使用commons-fileupload實現單個和多個文件上傳

    對于實現文件上傳功能來說,Commons-fileupload組件是一個不錯的選擇,本文使用它實現了單個文件及多個文件上傳,這里將實現過程寫出來與大家共享。

    1.單個文件上傳。
    頁面代碼:
           
    ....
    <div id="content">
                
    <fieldset><legend>下載列表</legend>
                    
    <ul>
                    
    <%
                        List
    <String> downloadList=(List<String>)request.getAttribute("downloadList");    
                        
                        
    if(downloadList!=null){
                            
    for(String str:downloadList){    
                                out.print(
    "<li><a href='DownloadFile?file="+str+"'>"+str+"</a></li>");
                            }
                        }
                    
    %>
                    
    </ul>
                
    </fieldset>
            
                
    <!-- enctype屬性為表單定義了MIME編碼方式,上傳文件的表單enctype屬性必須如此設置 -->
                
    <form method="post" action="UploadFile" enctype="multipart/form-data" >
                
    <p><input type="text" name="fileIntro" value="" />文件介紹</p>
                
    <p><input type="file" name="myfile1" value="瀏覽文件" /></p>
                
    <p><input type="submit" value="上傳"/></p>
                
    </form>
            
    </div>....
    在上傳表單中,既有普通文本域也有文件上傳域,注意在Servlet中取它們和平常的做法不同:
    Servlet代碼:
    package com.sitinspring.action;

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

    import javax.servlet.RequestDispatcher;
    import javax.servlet.ServletException;
    import javax.servlet.http.HttpServlet;
    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;

    import org.apache.commons.fileupload.FileItem;
    import org.apache.commons.fileupload.FileItemFactory;
    import org.apache.commons.fileupload.disk.DiskFileItemFactory;
    import org.apache.commons.fileupload.servlet.ServletFileUpload;

    import com.sitinspring.util.UploadUtil;

    /**
     * 用于文件上傳處理的Servlet
     * 
    @author sitinspring
     *
     * @date 2008-2-12
     
    */
    public class UploadFileServlet extends HttpServlet {
        
    private static final long serialVersionUID = 56890894234786L;

        @SuppressWarnings(
    "unchecked")
        
    public void doPost(HttpServletRequest request, HttpServletResponse response)
                
    throws ServletException, java.io.IOException {
            request.setCharacterEncoding(
    "UTF-8");

            
    // 文件上傳部分
            boolean isMultipart = ServletFileUpload.isMultipartContent(request);
            
            
    if (isMultipart == true) {
                
    try {
                    FileItemFactory factory 
    = new DiskFileItemFactory();
                    ServletFileUpload upload 
    = new ServletFileUpload(factory);
                    
                    
    // 得到所有的表單域,它們目前都被當作FileItem
                    List<FileItem> fileItems = upload.parseRequest(request);
                    Iterator
    <FileItem> iter = fileItems.iterator();
                    
                    
    // 依次處理每個表單域
                    while (iter.hasNext()) {
                        FileItem item 
    = (FileItem) iter.next();
                        
                        
    if(item.isFormField()){
                            
    // 如果item是正常的表單域
                            String name = item.getFieldName();
                            String value 
    = item.getString();
                            System.out.print(
    "表單域名為:"+name+"表單域值為:"+value);
                        }
                        
    else{
                            
    // 如果item是文件上傳表單域
                            
                            
    // 獲得文件名及路徑
                            String fileName = item.getName();
                            
    if (fileName != null) {
                                File fullFile 
    = new File(item.getName());                            
                                                            
                                
    // 如果文件存在則上傳
                                if(fullFile.exists()){
                                    File fileOnServer 
    = new File(UploadUtil.getUploadPath(),
                                            fullFile.getName());
                                    item.write(fileOnServer);
                                    
                                    System.out.println(
    "文件"+fileOnServer.getName()+"上傳成功");
                                }
                            }
                        }
                    }                
                } 
    catch (Exception e) {
                    e.printStackTrace();
                }
            } 
    else {
                System.out.println(
    "the enctype must be multipart/form-data");
            }
            
            
    // 取得服務器中已有文件的下載列表
            List<String> fileListInServer=new ArrayList<String>(); 
            
            File dir 
    = new File(UploadUtil.getUploadPath());        
            String[] children 
    = dir.list();
            
    if (children != null) {
                
    for (int i=0; i<children.length; i++) {
                    fileListInServer.add(children[i]);                
                }
            }
            
            request.setAttribute(
    "downloadList", fileListInServer);

            
    // 跳回原頁面
            RequestDispatcher dispatcher = request
                    .getRequestDispatcher(
    "/web/page/uploadtoserver.jsp");
            dispatcher.forward(request, response);
            
    return;
        }

        
    public void doGet(HttpServletRequest request, HttpServletResponse response)
                
    throws ServletException, java.io.IOException {
            doPost(request, response);
        }
    }

    從上面的代碼可以看出,無論是否文件上傳表單域都被當成了FileItem來處理,要區別開來使用isFormField()方法即可,返回真是常規表單域,返回假則是文件上傳表單域。

    2.多個文件上傳到服務器端。

    這里采用JS動態生成幾個文件上傳表單域即可,Servlet無需改變。
    多文件上傳頁面代碼如下:
    <%@ page contentType="text/html; charset=UTF-8"%>
    <%@page language="java" import="java.util.List"%>

    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
    <html>
    <head>
    <title>上傳多個文件到服務器</title>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
    <link rel="stylesheet" rev="stylesheet" href="web/css/style.css"
        type
    ="text/css" />
    </head>

    <body>
        
    <div id="bodyDiv">
            
    <div id="header">
                
    <jsp:include page="/web/page/branch/header.jsp"/>
            
    </div>
            
    <div id="sidebar">
                
    <jsp:include page="/web/page/branch/sidebar.jsp"/>
            
    </div>
            
    <div id="content">
                
    <fieldset><legend>下載列表</legend>
                    
    <ul>
                    
    <%
                        List
    <String> downloadList=(List<String>)request.getAttribute("downloadList");    
                        
                        
    if(downloadList!=null){
                            
    for(String str:downloadList){    
                                out.print(
    "<li><a href='DownloadFile?file="+str+"'>"+str+"</a></li>");
                            }
                        }
                    
    %>
                    
    </ul>
                
    </fieldset>
            
                
    <!-- enctype屬性為表單定義了MIME編碼方式,上傳文件的表單enctype屬性必須如此設置 -->
                
    <form name="uploadForm" method="post" action="UploadFile" enctype="multipart/form-data" >
                
    <p><input type="button" value="增加上傳按鈕" onclick="addUploadButton()"/></p>
                
    <p><input type="file" name="myfile1" value="瀏覽文件" /></p>
                
    <p><input type="submit" value="上傳"/></p>
                
    </form>
            
    </div>
            
    <div id="footer">
                
    <jsp:include page="/web/page/branch/footer.jsp"/>
            
    </div>
        
    </div>
    </body>

    JS代碼:
    <script LANGUAGE="JavaScript">
    <!--
    var count=1;

    function addUploadButton(){    
        
    // 按ID找到FOrm
        var uploadForm=document.getElementById("uploadForm");    
        
        
    // 創建P元素
        var pNode=document.createElement("p");
        
        
    // 累加Count以觀察次數
        count=count+1;
        
        pNode.innerHTML
    ="<input type='file' name='myfile"+count+"' value='瀏覽文件'/>";
        
        
    // 將P元素添加到body中
        uploadForm.appendChild(pNode);
    }

    //-->
    </script>
    </html>


    實例代碼:
    http://m.tkk7.com/Files/sitinspring/FileUpload20080412145412.rar



    posted on 2008-04-12 14:16 sitinspring 閱讀(34030) 評論(13)  編輯  收藏 所屬分類: Web開發

    評論

    # re: 使用commons-fileupload實現單個和多個文件上傳 2008-04-14 17:21 anthony.rao

    會不會有中文問題?  回復  更多評論   

    # re: 使用commons-fileupload實現單個和多個文件上傳 2008-04-14 17:22 anthony.rao

    就是下載的時候.用href直接連過去 ,要是文件名稱是中文的話,有問題嗎?  回復  更多評論   

    # re: 使用commons-fileupload實現單個和多個文件上傳 2008-04-14 17:40 如坐春風

    @anthony.rao

    有中文問題,有待發掘一下.  回復  更多評論   

    # re: 使用commons-fileupload實現單個和多個文件上傳 2008-12-03 13:21 e

    中文問題有沒有一個很好的解決辦法 希望能指教下  回復  更多評論   

    # re: 使用commons-fileupload實現單個和多個文件上傳 2009-03-04 11:45 zth

    我也來頂一個。樓主好樣的。。。擾屏對不起樓主,頂下..本人自己開培訓部,
    如果有感興趣的同學,可以利用以下的聯系方式聯系我們,感謝大家的支持,歡迎咨詢
    福建省福州市戰虎軟件研發中心俱樂部===火熱報名中……
    戰虎軟件研發中心俱樂部歡迎您:走在軟件開發安全的最前沿
    本培訓中心選修課程如下:
    企業軟件研發 軟件架構設計 SQL注入 遠程控制 木馬研究 2D游戲研發 3D游戲研究 外掛研究 3D游戲研究 數據庫設計
    涉及的語言有:ASP.NET-C#......JAVA……C++……MASM32……PHP……FLASH AS3
    地址:福建省福州市倉山區福建師范大學附近
    如要咨詢詳情,撥打電話:15005086322進行咨詢
    聯系方式:張老師15005086322|QQ:張老師920358479,張助理364823620
    Email:zse555@fight-tiger.com|網址:http://www.fight-tiger.com
      回復  更多評論   

    # re: 使用commons-fileupload實現單個和多個文件上傳[未登錄] 2009-03-17 21:47 1

    so good!~~  回復  更多評論   

    # re: 使用commons-fileupload實現單個和多個文件上傳 2009-08-06 18:53 help

    UploadUtil 在那里定義的?怎么找不到,能把代碼貼出來嗎  回復  更多評論   

    # re: 使用commons-fileupload實現單個和多個文件上傳 2009-09-08 17:59 miffy

    寫的很詳細,謝謝分享!  回復  更多評論   

    # re: 使用commons-fileupload實現單個和多個文件上傳 2009-10-24 15:21 roundzheng

    很不錯,真的我調試了,很成功!  回復  更多評論   

    # re: 使用commons-fileupload實現單個和多個文件上傳[未登錄] 2010-03-31 16:41 df

    ff  回復  更多評論   

    # re: 使用commons-fileupload實現單個和多個文件上傳[未登錄] 2010-03-31 16:42 df

    fdfd  回復  更多評論   

    # re: 使用commons-fileupload實現單個和多個文件上傳[未登錄] 2010-03-31 16:42 df











































































































































































































    fdfd



    dfd
      回復  更多評論   

    # re: 使用commons-fileupload實現單個和多個文件上傳 2012-12-13 10:37 存儲

    @help
    。。。我也想知道這個問題  回復  更多評論   

    sitinspring(http://m.tkk7.com)原創,轉載請注明出處.
    主站蜘蛛池模板: 国产成人免费a在线资源| 好爽又高潮了毛片免费下载| 亚洲人成无码www久久久| 美女黄频视频大全免费的| 日本一道在线日本一道高清不卡免费 | 午夜色a大片在线观看免费| 亚洲AV永久无码精品成人| 拍拍拍无挡视频免费观看1000| 激情综合色五月丁香六月亚洲| 国产精品一区二区三区免费| 久久亚洲色一区二区三区| 三级网站在线免费观看| 亚洲成年轻人电影网站www| **毛片免费观看久久精品| 亚洲一区二区三区91| 国产福利免费观看| 韩国免费A级毛片久久| 亚洲成色999久久网站| 丁香花免费完整高清观看| 亚洲av日韩专区在线观看| 亚洲国产成人久久笫一页| 色www永久免费网站| 亚洲精品美女久久久久9999| 免费中文熟妇在线影片| 男女猛烈激情xx00免费视频| 亚洲乱亚洲乱妇无码麻豆| 麻豆视频免费播放| 自拍偷自拍亚洲精品偷一| 伊人久久精品亚洲午夜| 亚洲视频免费一区| 成人精品国产亚洲欧洲| 亚洲AV无一区二区三区久久| 九九精品免费视频| 又粗又长又爽又长黄免费视频 | 2020亚洲男人天堂精品| 亚洲成av人片在线观看天堂无码| 中文字幕无码一区二区免费| 亚洲一区二区三区精品视频| 精品亚洲视频在线观看| 99精品视频在线观看免费专区| 亚洲精品乱码久久久久久V |