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

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

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

    RockFeeling

    常用鏈接

    統(tǒng)計(jì)

    最新評(píng)論

    2012年2月18日 #

    servlet + html 圖片上傳

    Servlet:

    package cn.com.seegoo.xm.front.servlets;

    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.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;

    import org.apache.commons.fileupload.FileItem;
    import org.apache.commons.fileupload.FileUploadBase.SizeLimitExceededException;
    import org.apache.commons.fileupload.FileUploadException;
    import org.apache.commons.fileupload.disk.DiskFileItemFactory;
    import org.apache.commons.fileupload.servlet.ServletFileUpload;

    import cn.com.seegoo.servletrest.servlets.BaseServlet;

    public class PhotoUpServlet extends BaseServlet{
     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 PhotoUpServlet() {
            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è)硬盤文件工廠,用來(lái)配置上傳組件ServletFileUpload
            DiskFileItemFactory dfif = new DiskFileItemFactory();
            dfif.setSizeThreshold(4096);// 設(shè)置上傳文件時(shí)用于臨時(shí)存放文件的內(nèi)存大小,這里是4K.多于的部分將臨時(shí)存在硬盤
            dfif.setRepository(new File(request.getRealPath("/")
                    + "upload"));// 設(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) {// 處理文件尺寸過(guò)大異常
                if (e instanceof SizeLimitExceededException) {
                    out.println("{message:'文件尺寸超過(guò)規(guī)定大小:"+MAX_SIZE+"字節(jié)'}");
                    return;
                }
                e.printStackTrace();
            }
            // 沒(méi)有文件上傳
            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ò)展名(無(wú)擴(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;
                //原來(lái)的文件名
                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();
                }

            }
        }

    }



    JS:

    function ajaxFileUpload()
        {
           
            $("#loading")
            .ajaxStart(function(){
                $(this).show();
            })//開始上傳文件時(shí)顯示一個(gè)圖片
            .ajaxComplete(function(){
                $(this).hide();
            });//文件上傳完成將圖片隱藏起來(lái)
           
            $.ajaxFileUpload
            (
                {
                    url:'PhotoUpServlet',//用于文件上傳的服務(wù)器端請(qǐng)求地址
                    secureuri:false,//一般設(shè)置為false
                    fileElementId:'fileField',//文件上傳空間的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;

        }

    界面:

    <body>

     <img src="images/loading.gif" id="loading" style="display: none;">

       <span style="color: red;" id="myspan"></span><br/>

            <input type="file" id="fileField" name="file" />
            <br />
            <input type="button" value="上傳" onclick="return ajaxFileUpload();">
    </body>

    web.xml:

    <servlet>
            <servlet-name>PhotoUpServlet</servlet-name>
            <servlet-class>cn.com.seegoo.xm.front.servlets.PhotoUpServlet</servlet-class>
        </servlet>
        <servlet-mapping>
            <servlet-name>PhotoUpServlet</servlet-name>
            <url-pattern>/PhotoUpServlet</url-pattern>
        </servlet-mapping>

    posted @ 2012-02-18 15:06 將風(fēng)度養(yǎng)成 閱讀(791) | 評(píng)論 (0)編輯 收藏

    2012年2月7日 #

    Javascript刷新頁(yè)面的幾種方法(摘自網(wǎng)絡(luò))

    Javascript刷新頁(yè)面的幾種方法: 
    1 history.go(0) 
    2 location.reload() 
    3 location=location 
    4 location.assign(location) 
    5 document.execCommand('Refresh') 
    6 window.navigate(location) 
    7 location.replace(location) 
    8 document.URL=location.href 
    二、自動(dòng)刷新頁(yè)面 
    1.頁(yè)面自動(dòng)刷新:把如下代碼加入<head>區(qū)域中 
    <meta http-equiv="refresh" content="20"> 
    其中20指每隔20秒刷新一次頁(yè)面. 
    2.頁(yè)面自動(dòng)跳轉(zhuǎn):把如下代碼加入<head>區(qū)域中 
    <meta http-equiv="refresh" content="20;url=http://www.jb51.net"> 
    其中20指隔20秒后跳轉(zhuǎn)到http://www.jb51.net頁(yè)面 
    3.頁(yè)面自動(dòng)刷新js版 
    <script language="JavaScript"> 
    function myrefresh() 
    window.location.reload(); 
    setTimeout('myrefresh()',1000); //指定1秒刷新一次 
    </script> 
    三、java在寫Servler,Action等程序時(shí),要操作返回頁(yè)面的話(如談出了窗口,操作完成以后,關(guān)閉當(dāng)前頁(yè)面,刷新父頁(yè)面) 
    1 PrintWriter out = response.getWriter(); 
    2 out.write("<script type=\"text/javascript\">"); 
    3 ////子窗口刷新父窗口 
    4 out.write("self.opener.location.reload();"); 
    5 //關(guān)閉窗口 
    6 out.write("window.opener=null;"); 
    7 out.write("window.close();"); 
    8 out.write("</script>"); 
    四、JS刷新框架的腳本語(yǔ)句 
    1.如何刷新包含該框架的頁(yè)面用 
    <script language=JavaScript> 
    parent.location.reload(); 
    </script> 
    2.子窗口刷新父窗口 
    <script language=JavaScript> 
    self.opener.location.reload(); 
    </script> 
    3.如何刷新另一個(gè)框架的頁(yè)面用 (上面的實(shí)例以說(shuō)明了) 
    語(yǔ)句1. window.parent.frames[1].location.reload(); 
    語(yǔ)句2. window.parent.frames.bottom.location.reload(); 
    語(yǔ)句3. window.parent.frames["bottom"].location.reload(); 
    語(yǔ)句4. window.parent.frames.item(1).location.reload(); 
    語(yǔ)句5. window.parent.frames.item('bottom').location.reload(); 
    語(yǔ)句6. window.parent.bottom.location.reload(); 
    語(yǔ)句7. window.parent['bottom'].location.reload(); 
    4.如果想關(guān)閉窗口時(shí)刷新或者想開窗時(shí)刷新的話,在<body>中調(diào)用以下語(yǔ)句即可。 
    <body onload="opener.location.reload()"> 
    開窗時(shí)刷新 
    <body onUnload="opener.location.reload()"> 
    關(guān)閉時(shí)刷新 
    <script language="javascript"> 
    window.opener.document.location.reload() 
    </script> 

    posted @ 2012-02-07 00:08 將風(fēng)度養(yǎng)成 閱讀(175) | 評(píng)論 (0)編輯 收藏

    僅列出標(biāo)題  
    主站蜘蛛池模板: 中国一级特黄的片子免费 | 亚洲精品国产啊女成拍色拍| 日本黄页网址在线看免费不卡| 日本一区免费电影| 亚洲av无码一区二区三区人妖 | 精品免费国产一区二区| 亚洲熟妇无码AV不卡在线播放| 扒开双腿猛进入爽爽免费视频| 亚洲五月综合缴情婷婷| 无人影院手机版在线观看免费| 国产成人亚洲综合网站不卡| 女人张开腿给人桶免费视频| 在线观看亚洲免费视频| 免费人成在线观看播放国产| 免费视频精品一区二区| 久久精品国产亚洲7777| 免费无码av片在线观看| 亚洲精品视频在线播放| 猫咪社区免费资源在线观看 | 国产大片91精品免费看3| 特级毛片aaaa免费观看| 亚洲精品高清国产一线久久| 久久精品电影免费动漫| 亚洲国产成+人+综合| 国产免费131美女视频| 91在线免费观看| 亚洲国产精品免费在线观看| 最近中文字幕mv手机免费高清| 特级毛片全部免费播放| 国产亚洲精品a在线无码| 午夜国产精品免费观看| 天天综合亚洲色在线精品| 亚洲午夜久久久影院伊人| 18禁男女爽爽爽午夜网站免费| 亚洲精品美女久久7777777| 精品亚洲一区二区三区在线播放| 久久国产免费一区二区三区| 亚洲午夜福利在线视频| 浮力影院亚洲国产第一页| 国产成人福利免费视频| 一级做α爱过程免费视频|