<u id="1k2el"></u>
<u id="1k2el"></u>

      咨詢電話:0551-62903161

      學術交流

      首頁>官網首頁 > 教育教學 > 學術交流 >
      青鳥老師教你如何ajax結合java上傳文件
      作者:未知  時間:2018-12-29 17:06
      js 的 XMLHttpRequest Level 2添加了一個新的接口FormData.利用FormData對象,我們可以通過JavaScript用一些鍵值對來模擬一系列表單控件,我們還可以使用XMLHttpRequest的send()方法來異步的提交這個"表單".比起普通的ajax,使用FormData的最大優點就是我們可以異步上傳一個二進制文件.
      表單如下:
       
      <%page language="java"   pageEncoding="utf-8"%>
      <!DOCTYPE HTML>
      <html>
      <head>
      <meta http-equiv="pragma" content="no-cache">
      <meta http-equiv="cache-control" content="no-cache">
      <meta http-equiv="expires" content="0">
      <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
      <meta http-equiv="description" content="This is my page">
      <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
      <title></title>
      <link href="css/admin.css" rel="stylesheet" type="text/css" />
      <script type="text/javascript" src="js/jquery-1.11.1.js"></script>
      <script type="text/javascript">
      $(function(){
          $("#upload").click(function(event){
               event.preventDefault();
              
              var f=$("#uploadForm")[0];//dom
              //alert(f.action+">>>>>");
              var mydata=new FormData(f);//利用form創建對象。mydata.append以手工添加對象
              //
              /**$.post("upload.do",data,function(d){
                  alert(d);
              });**/
              $.ajax({
                  url:"upload.do",
                  type:"POST",
                  data:mydata,
                  contentType:false,
                  processData:false,
                  success:function(d){alert(d);f.reset();}
              });
          });
          //
          $("#nfile").change(function(){
              
              var file=this.files[0];
              var preview=$("#preview").get(0);
              
              var reader = new FileReader();
               reader.onloadend = function () {
                preview.src = reader.result;
               }
               if (file) {
                reader.readAsDataURL(file);
               } else {
                preview.src = "";
               }
          });
      });
      </script>
      </head>
      <body>
      <div id="header">
        <div id="welcome">使</div>
        <div id="nav">
          <div id="logo"><img src="images/logo.jpg" alt="" /></div>
          <div id="a_b01"><img src="images/a_b01.gif" alt="" /></div>
        </div>
      </div>
       
      <div id="main">
        <div id="opt_area">    
       <h1 id="opt_type">  </h1>
          <form action="upload.do"  enctype="multipart/form-data" method="post" id="uploadForm">
          
            <p>
              <label>  </label>
              <input name="ntitle" id="ntitle" type="text" class="opt_input" />
            </p>
            <p>
              <label>  </label>
              <input name="nauthor" id="nauthor" name="nauthor" type="text" class="opt_input" />
            </p>
            
            <p>
              <label>  </label>        
               <img src="" id="preview" height="200" width="300" alt=""/><br/>
              <input type="file" name="nfile" id="nfile"/>
             
            </p> 
            <input type="submit" value="" class="opt_sub" id="upload" />
            <input type="reset" value="" class="opt_sub" />
          </form>
        </div>
      </div>
      </body>
      </html>
       
      后臺的處理按照正常的文件上傳處理,如下的代碼采用common-upload
       
              request.setCharacterEncoding("utf-8");
              // response.setCharacterEncoding("utf-8");
              response.setContentType("text/html;charset=utf-8");
              DiskFileItemFactory d = new DiskFileItemFactory();
              ServletFileUpload up = new ServletFileUpload(d);
              up.setHeaderEncoding("utf-8");// 
              try {
                  List<FileItem> fields = up.parseRequest(request);// 
                  String picPath = super.getServletContext().getRealPath("images");// 
                  String title = nullauthor = null;
                  for (FileItem f : fields) {
                      if (f.isFormField()) {
                          if (f.getFieldName().equals("ntitle"))
                              title = f.getString("utf-8");
                          else if (f.getFieldName().equals("nauthor"))
                              author = f.getString("utf-8");
                          // ....
                      } else {
                          if (f.getName() == "")
                              continue;
                          String newFileName = f.getName();
                          f.write(new java.io.File(picPathnewFileName));
                          // 
                      }
                  }
              } catch (Exception e1) {
                  // 
                  e1.printStackTrace();
                  response.getWriter().print("");
                  // response.sendError(500, "" + e1.getLocalizedMessage());
                  return;
              }
              // request.setAttribute("msg", "");
              // response.sendRedirect("newsServlet");
              response.getWriter().print("");
          
       
      友情鏈接:北大青鳥科海學院合肥濱湖職業技術學院合肥公交技校 安徽衛生健康職業學院
      獲獎信息:

      地鐵:乘地鐵1號線到合工大南區B出口,向南800米即到。

      聯系我們:招生老師15056993965(微信手機同號) ? ? ?0551-62903161

      地址:合肥市包河區馬鞍山路富成大廈4樓北大青鳥(合工大東門斜對面)

      日韩黄色毛片在线观看_96精品人妻大胆无码_亚洲一区二区在线波多野_在线视频一区二区三期
      <u id="1k2el"></u>
      <u id="1k2el"></u>

          日韩精品另类图区中文字幕 | 日韩一中文字幕在线 | 亚洲国产精品久久无套 | 亚洲欧美另类国产制服 | 亚洲日韩精品第一页一区 | 亚洲日本va午夜在线电影 |