RockFeeling

          常用鏈接

          統(tǒ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");

                  // 實例化一個硬盤文件工廠,用來配置上傳組件ServletFileUpload
                  DiskFileItemFactory dfif = new DiskFileItemFactory();
                  dfif.setSizeThreshold(4096);// 設(shè)置上傳文件時用于臨時存放文件的內(nèi)存大小,這里是4K.多于的部分將臨時存在硬盤
                  dfif.setRepository(new File(request.getRealPath("/")
                          + "upload"));// 設(shè)置存放臨時文件的目錄,web根目錄下的uploadtemp目錄
                  // 用以上工廠實例化上傳組件
                  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:'請選擇上傳文件'}");
                      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();
                      // 忽略簡單form字段而不是上傳域的文件域(<input type="text" />等)
                      if (fileItem == null || fileItem.isFormField()) {
                          continue;
                      }
                      // 得到文件的完整路徑
                      path = fileItem.getName();
                      // 得到文件的大小
                      size = fileItem.getSize();
                      if ("".equals(path) || size == 0) {
                          out.println("{message:'請選擇上傳文件'}");
                          return;
                      }

                      // 得到去除路徑的文件名
                      String t_name = path.substring(path.lastIndexOf("\\") + 1);
                      // 得到文件的擴展名(無擴展名時將得到全名)
                      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:'請上傳以下類型的文件"+message+"'}");
                          return;
                      }

                      long now = System.currentTimeMillis();
                      // 根據(jù)系統(tǒng)時間生成上傳后保存的文件名
                      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();
                      }

                  }
              }

          }



          JS:

          function ajaxFileUpload()
              {
                 
                  $("#loading")
                  .ajaxStart(function(){
                      $(this).show();
                  })//開始上傳文件時顯示一個圖片
                  .ajaxComplete(function(){
                      $(this).hide();
                  });//文件上傳完成將圖片隱藏起來
                 
                  $.ajaxFileUpload
                  (
                      {
                          url:'PhotoUpServlet',//用于文件上傳的服務(wù)器端請求地址
                          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)成 閱讀(793) | 評論 (0)編輯 收藏

          2012年2月7日 #

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

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

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

          僅列出標(biāo)題  
          主站蜘蛛池模板: 克什克腾旗| 威信县| 南皮县| 乳源| 白银市| 鲜城| 十堰市| 西城区| 元谋县| 格尔木市| 霞浦县| 怀化市| 廉江市| 南涧| 芮城县| 永州市| 东阿县| 福清市| 天气| 定襄县| 隆化县| 防城港市| 潮州市| 靖安县| 洪洞县| 灵山县| 南丰县| 库车县| 永靖县| 林周县| 砚山县| 佛学| 德安县| 易门县| 宁国市| 沈丘县| 宜君县| 龙胜| 温泉县| 额敏县| 霍林郭勒市|