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

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

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

    溫馨提示:您的每一次轉(zhuǎn)載,體現(xiàn)了我寫此文的意義!!!煩請(qǐng)您在轉(zhuǎn)載時(shí)注明出處http://m.tkk7.com/sxyx2008/謝謝合作!!!

    雪山飛鵠

    溫馨提示:您的每一次轉(zhuǎn)載,體現(xiàn)了我寫此文的意義!!!煩請(qǐng)您在轉(zhuǎn)載時(shí)注明出處http://m.tkk7.com/sxyx2008/謝謝合作!!!

    BlogJava 首頁(yè) 新隨筆 聯(lián)系 聚合 管理
      215 Posts :: 1 Stories :: 674 Comments :: 0 Trackbacks
    package com.future.zfs.util;

    import java.io.File;
    import java.io.IOException;
    import java.io.PrintWriter;
    import java.util.Iterator;
    import java.util.List;

    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.FileUploadException;
    import org.apache.commons.fileupload.FileUploadBase.SizeLimitExceededException;
    import org.apache.commons.fileupload.disk.DiskFileItemFactory;
    import org.apache.commons.fileupload.servlet.ServletFileUpload;

    @SuppressWarnings(
    "serial")
    public class FileUploadServlet extends HttpServlet {

        
    final long MAX_SIZE = 10 * 1024 * 1024;// 設(shè)置上傳文件最大為 10M
        
    // 允許上傳的文件格式的列表
        final String[] allowtype = new String[] {"jpg","jpeg","gif","txt","doc","docx","mp3","wma","m4a","xls"};

        
    public FileUploadServlet() {
            
    super();
        }

        
    public void destroy() {
            
    super.destroy(); 
        }

        @Override
        
    protected void service(HttpServletRequest request, HttpServletResponse response)
                
    throws ServletException, IOException {
            response.setContentType(
    "text/html");
            
    // 設(shè)置字符編碼為UTF-8, 這樣支持漢字顯示
            response.setCharacterEncoding("UTF-8");

            
    // 實(shí)例化一個(gè)硬盤文件工廠,用來配置上傳組件ServletFileUpload
            DiskFileItemFactory dfif = new DiskFileItemFactory();
            dfif.setSizeThreshold(
    4096);// 設(shè)置上傳文件時(shí)用于臨時(shí)存放文件的內(nèi)存大小,這里是4K.多于的部分將臨時(shí)存在硬盤
            dfif.setRepository(new File(request.getRealPath("/")
                    
    + "uploadtemp"));// 設(shè)置存放臨時(shí)文件的目錄,web根目錄下的uploadtemp目錄
            
    // 用以上工廠實(shí)例化上傳組件
            ServletFileUpload sfu = new ServletFileUpload(dfif);
            
    // 設(shè)置最大上傳尺寸
            sfu.setSizeMax(MAX_SIZE);

            PrintWriter out 
    = response.getWriter();
            
    // 從request得到 所有 上傳域的列表
            List fileList = null;
            
    try {
                fileList 
    = sfu.parseRequest(request);
            } 
    catch (FileUploadException e) {// 處理文件尺寸過大異常
                if (e instanceof SizeLimitExceededException) {
                    out.println(
    "{message:'文件尺寸超過規(guī)定大小:"+MAX_SIZE+"字節(jié)'}");
                    
    return;
                }
                e.printStackTrace();
            }
            
    // 沒有文件上傳
            if (fileList == null || fileList.size() == 0) {
                out.println(
    "{message:'請(qǐng)選擇上傳文件'}");
                
    return;
            }
            
    // 得到所有上傳的文件
            Iterator fileItr = fileList.iterator();
            
    // 循環(huán)處理所有文件
            while (fileItr.hasNext()) {
                FileItem fileItem 
    = null;
                String path 
    = null;
                
    long size = 0;
                
    // 得到當(dāng)前文件
                fileItem = (FileItem) fileItr.next();
                
    // 忽略簡(jiǎn)單form字段而不是上傳域的文件域(<input type="text" />等)
                if (fileItem == null || fileItem.isFormField()) {
                    
    continue;
                }
                
    // 得到文件的完整路徑
                path = fileItem.getName();
                
    // 得到文件的大小
                size = fileItem.getSize();
                
    if ("".equals(path) || size == 0) {
                    out.println(
    "{message:'請(qǐng)選擇上傳文件'}");
                    
    return;
                }

                
    // 得到去除路徑的文件名
                String t_name = path.substring(path.lastIndexOf("\\"+ 1);
                
    // 得到文件的擴(kuò)展名(無擴(kuò)展名時(shí)將得到全名)
                String t_ext = t_name.substring(t_name.lastIndexOf("."+ 1);
                
    // 拒絕接受規(guī)定文件格式之外的文件類型
                int allowFlag = 0;
                
    int allowedExtCount = allowtype.length;
                
    for (; allowFlag < allowedExtCount; allowFlag++) {
                    
    if (allowtype[allowFlag].equals(t_ext))
                        
    break;
                }
                
    if (allowFlag == allowedExtCount) {
                    String message 
    = "";
                    
    for (allowFlag = 0; allowFlag < allowedExtCount; allowFlag++){
                        message
    +="*." + allowtype[allowFlag]
                                                    
    + " ";
                    }
                    out.println(
    "{message:'請(qǐng)上傳以下類型的文件"+message+"'}");
                    
    return;
                }

                
    long now = System.currentTimeMillis();
                
    // 根據(jù)系統(tǒng)時(shí)間生成上傳后保存的文件名
                String prefix = String.valueOf(now);
                
    // 保存的最終文件完整路徑,保存在web根目錄下的upload目錄下
                String u_name = request.getRealPath("/"+ "upload/"
                        
    + prefix + "." + t_ext;
                
    //原來的文件名
                path=request.getRealPath("/"+ "upload/"+path;
                
    try {
                    
    // 保存文件
                    fileItem.write(new File(path));
                    response.setStatus(
    200);
                    out.println(
    "{message:\"文件上傳成功. 已保存為: " + prefix + "." + t_ext
                            + " 文件大小: " + size + "字節(jié)\"}");
                } catch (Exception e) {
                    e.printStackTrace();
                }

            }
        }
    }
    web.xml
    <servlet>
            
    <servlet-name>fileUploadServlet</servlet-name>
            
    <servlet-class>com.future.zfs.util.FileUploadServlet</servlet-class>
        
    </servlet>
        
    <servlet-mapping>
            
    <servlet-name>fileUploadServlet</servlet-name>
            
    <url-pattern>/fileUploadServlet</url-pattern>
        
    </servlet-mapping>
    上傳頁(yè)面
    <%@ page language="java" contentType="text/html; charset=UTF-8"
        pageEncoding
    ="UTF-8"%>
    <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
    <html>
        
    <head>
            
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
            
    <title>Insert title here</title>
            
    <script type="text/javascript" src="js/jquery.js"></script>
            
    <script type="text/javascript" src="js/ajaxfileupload.js"></script>
            
    <script type="text/javascript">
        
    function ajaxFileUpload()
        {
            
            $(
    "#loading")
            .ajaxStart(
    function(){
                $(
    this).show();
            })
    //開始上傳文件時(shí)顯示一個(gè)圖片
            .ajaxComplete(function(){
                $(
    this).hide();
            });
    //文件上傳完成將圖片隱藏起來
            
            $.ajaxFileUpload
            (
                {
                    url:'fileUploadServlet',
    //用于文件上傳的服務(wù)器端請(qǐng)求地址
                    secureuri:false,//一般設(shè)置為false
                    fileElementId:'file',//文件上傳空間的id屬性  <input type="file" id="file" name="file" />
                    dataType: 'json',//返回值類型 一般設(shè)置為json
                    success: function (data, status)  //服務(wù)器成功響應(yīng)處理函數(shù)
                    {
                        
    //alert(data.message);//從服務(wù)器返回的json中取出message中的數(shù)據(jù),其中message為在struts2中定義的成員變量
                        $('#myspan').html(data.message);
                        
    if(typeof(data.error) != 'undefined')
                        {
                            
    if(data.error != '')
                            {
                                
    //alert(data.error);
                                $('#myspan').html(data.message);
                            }
    else
                            {
                                
    //alert(data.message);
                                $('#myspan').html(data.message);
                            }
                        }
                    },
                    error: 
    function (data, status, e)//服務(wù)器響應(yīng)失敗處理函數(shù)
                    {
                        
    //alert(e);
                        $('#myspan').html(e);
                    }
                }
            )
            
            
    return false;

        }
        
    </script>
        
    </head>
        
    <body>
            
    <img src="images/loading.gif" id="loading" style="display: none;">
            
    <span style="color: red;" id="myspan"></span><br/>
            
    <input type="file" id="file" name="file" />
            
    <br />
            
    <input type="button" value="上傳" onclick="return ajaxFileUpload();">
            
    <href="fileDownLoadServlet?filename=通訊錄.xls">哈哈,測(cè)試文件下載</a>
        
    </body>
    </html>
    需要注意的是:在使用ajaxFileUpload基于servlet上傳時(shí)需要設(shè)置response.setContentType("text/html");盡管dataType: 'json'設(shè)置為json仍要設(shè)置response.setContentType("text/html");否則獲取不到服務(wù)器端返回的數(shù)據(jù)以及會(huì)彈出一個(gè)對(duì)話框
    這點(diǎn)與基于struts2的ajaxFileUpload上傳是不一樣的,可以參考之前寫的http://m.tkk7.com/sxyx2008/archive/2010/11/02/336826.html
    posted on 2010-12-10 17:19 雪山飛鵠 閱讀(5999) 評(píng)論(4)  編輯  收藏 所屬分類: js

    Feedback

    # re: 基于servlet的文件異步上傳 2010-12-12 23:41 yeshucheng
    我開始被標(biāo)題吸引了,我以為采用了JDK5線程異步方式呢,呵呵  回復(fù)  更多評(píng)論
      

    # re: 基于servlet的文件異步上傳 2013-08-04 16:42 李汶潼
    為什么我的總是顯示
    Uncaught TypeError: Object function (a,b){return new e.fn.init(a,b,h)} has no method 'ajaxFileUpload'
    呢 我確定JS都導(dǎo)入進(jìn)去了,但是還是不行
    是因?yàn)閖Query的版本嗎 我用的最1.9的 不知道有影響沒 ,但是我更換成你的代碼包里面的還是不對(duì)   回復(fù)  更多評(píng)論
      

    # re: 基于servlet的文件異步上傳 2014-06-03 14:28
    @李汶潼
    我現(xiàn)在也是遇到你一樣的問題,請(qǐng)問你這個(gè)問題解決了嗎?方便交流一下嗎  回復(fù)  更多評(píng)論
      

    # re: 基于servlet的文件異步上傳[未登錄] 2014-11-10 11:02 碼農(nóng)
    @龍
    @李汶潼
    還要導(dǎo)入jquery.upload.js  回復(fù)  更多評(píng)論
      

    主站蜘蛛池模板: 日日狠狠久久偷偷色综合免费| 精品一区二区三区高清免费观看| 国产精品色午夜免费视频| 美女视频黄a视频全免费网站色| 国产亚洲人成网站在线观看不卡| 最近中文字幕电影大全免费版| 亚洲精品无码久久久久牙蜜区| 亚洲中文无韩国r级电影 | 猫咪免费人成网站在线观看| 日韩亚洲不卡在线视频中文字幕在线观看 | 亚洲成a人片77777老司机| 中国在线观看免费国语版| 一级毛片免费视频网站| 亚洲精品午夜在线观看| 无码欧精品亚洲日韩一区夜夜嗨 | 91亚洲自偷手机在线观看| 国产精品酒店视频免费看| 日韩免费人妻AV无码专区蜜桃| 国产天堂亚洲国产碰碰| 亚洲专区在线视频| 免费大黄网站在线观| a拍拍男女免费看全片| 一级毛片不卡免费看老司机| 亚洲日本在线播放| 亚洲日韩精品射精日| 国产人成免费视频| 四虎在线免费视频| 国产免费一区二区三区不卡| 国产亚洲欧美日韩亚洲中文色| 久久精品a亚洲国产v高清不卡| 亚洲精品和日本精品| 午夜宅男在线永久免费观看网| 亚洲免费观看视频| 一本一道dvd在线观看免费视频| 中文字幕乱码亚洲精品一区| 亚洲激情视频在线观看| 久久国产成人亚洲精品影院| 国产美女a做受大片免费| 日韩av无码成人无码免费| 99re在线精品视频免费| a毛片免费观看完整|