亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

基于ajax實現文件上傳并顯示進度條

2019-11-20 11:56:05
字體:
來源:轉載
供稿:網友

下面給大家分享下基于ajax實現文件上傳并顯示進度條。在jsp部分,需要設計一個表單,form的屬性添加 enctype="multipart/form-data",設計一個iframe,作為隱藏。form的target等于iframe的name;

在servlet部分:文件上傳用的Commons-FileupLoad,需要兩個Jar,commons-fileupload和commons-io,少了第二個會報出找不到類的異常;

第一個servlet處理上傳,及把上傳進度保存到session,第二個servlet處理ajax請求,回傳session保存的進度值;

進度條:可以用ajax拿到回傳的進度值,改變圖片的width實現變化;

jsp代碼:

<%@ 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><link rel="stylesheet" type="text/css" href="css/progress.css"><script type="text/javascript" src="js/ul.js" charset="gbk"></script></head><body><form action="UploadServlet" name="f1" id="f1" method="post" enctype="multipart/form-data" target="if"> <input type="file" name="file1" /><br><br> <input type="reset" name="res1" value="重置"/> <input type="button" name="but1" value="提交" onclick="go();"/></form><br><div id="pro" class="pro" align="left"> <img alt="" src="photo/progress.png" width="0" height="15" id="imgpro"></div>  <span id="prop" style="width:15px;height:15px;display: none;">0%</span><iframe id="if" name="if" src="" style="display: none"></iframe></body></html>

這是index.jsp里的代碼:

提交后還在當前頁顯示進度,所以要用到iframe,提交后的返回放到隱藏的iframe里,不影響頁面效果;

css代碼:

復制代碼 代碼如下:

.pro{
  height:15px;
  width:500px;
  background: #FFFFF0;
  border: 1px solid #8FBC8F;
  margin: 0;
  padding: 0;
  display:none;
  position: relative;
  left:25px;
  float:left;
}

js代碼

function go(){ f1.submit(); document.getElementById("pro").style.display="block"; document.getElementById("prop").style.display=""; timer=setInterval("getP()",50); }var xmlHttpRequest;function getP(){  if(window.XmlHttpRequest){  xmlHttpRequest=new XmlHttpRequest(); }else{  xmlHttpRequest=new ActiveXObject("Microsoft.XMLHTTP"); }   xmlHttpRequest.onreadystatechange=callBack;  url="getProgressServlet"; xmlHttpRequest.open("post",url,true);  xmlHttpRequest.setRequestHeader("Content-type","application/x-www-form-urlencoded"); xmlHttpRequest.send("&timeStamp="+(new Date()).getTime());  }//回調函數function callBack(){  if(xmlHttpRequest.readyState==4 && xmlHttpRequest.status==200){     result=xmlHttpRequest.responseText;  var result=result.replace(/(^/s*)|(/s*$)/g, "");  var res=result.split(",");  var flag=res[1];   var per=parseInt(res[0]);  var err=res[2];  document.getElementById("imgpro").style.width=per*5+"px";  document.getElementById("prop").innerHTML=per+"%";  if(flag=="OK"){   window.clearInterval(timer);   alert("上傳成功!");   document.getElementById("pro").style.display="none";   document.getElementById("prop").innerHTML="";   f1.reset();  }  if(err!=""||err.length>0){   window.clearInterval(timer);   alert(err);  }  if(flag==null){   window.clearInterval(timer);  } }}

flag為上傳成功標記,err為出錯標記;

servlet代碼(UploadServlet):

package com.ul.servlet;import java.io.File;import java.io.FileOutputStream;import java.io.IOException;import java.io.InputStream;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 javax.servlet.http.HttpSession;import org.apache.commons.fileupload.FileItem;import org.apache.commons.fileupload.disk.DiskFileItemFactory;import org.apache.commons.fileupload.servlet.ServletFileUpload;public class UploadServlet extends HttpServlet {  protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {  doPost(request, response);  } protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {  //設置編碼格式為utf-8  request.setCharacterEncoding("utf-8");  response.setCharacterEncoding("utf-8");   //獲取session,保存進度和上傳結果,上傳結果初始值為NOK,當為Ok表示上傳完成  HttpSession session=request.getSession();  session.setAttribute("prog", "0");  session.setAttribute("result", "NOK");   session.setAttribute("error", "");  String error="";  //給上傳的文件設一個最大值,這里是不得超過50MB  int maxSize=50*1024*1024;  //創建工廠對象和文件上傳對象  DiskFileItemFactory factory=new DiskFileItemFactory();  ServletFileUpload upload=new ServletFileUpload(factory);  try {   //解析上傳請求   List items=upload.parseRequest(request);   Iterator itr=items.iterator();      while(itr.hasNext()){    FileItem item=(FileItem)itr.next();    //判斷是否為文件域    if(!item.isFormField()){     if(item.getName()!=null&&!item.getName().equals("")){      //獲取上傳文件大小和文件名稱      long upFileSize=item.getSize();         String fileName=item.getName();      if(upFileSize>maxSize){       error="您上傳的文件太大了,請選擇不超過50MB的文件!";       break;      }      //此時文件暫存在服務器的內存中,構造臨時對象      File tempFile=new File(fileName);      //指定文件上傳服務器的目錄及文件名稱      File file=new File("f://temp",tempFile.getName());      //構造輸入流讀文件      InputStream is=item.getInputStream();      int length=0;      byte[] by=new byte[1024];      double persent=0;      FileOutputStream fos=new FileOutputStream(file);      PrintWriter out=response.getWriter();      while((length=is.read(by))!=-1){       //計算文件進度       persent+=length/(double)upFileSize*100D;       fos.write(by, 0, length);       session.setAttribute("prog", Math.round(persent)+"");        Thread.sleep(10);      }      fos.close();      Thread.sleep(1000);     }else{      error="沒選擇上傳文件!";     }    }   }        } catch (Exception e) {   e.printStackTrace();   error="上傳文件出現錯誤:"+e.getMessage();  }  if(!error.equals("")){    session.setAttribute("error", error);  }else{   session.setAttribute("result", "OK");  } }}

不要忘記commons-io包

servlet代碼(getProgressServlet):

package com.ul.servlet;import java.io.IOException;import java.io.PrintWriter;import javax.servlet.ServletException;import javax.servlet.http.HttpServlet;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;import javax.servlet.http.HttpSession;public class getProgressServlet extends HttpServlet {  protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {  doPost(request, response); } protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {  request.setCharacterEncoding("utf-8");  response.setCharacterEncoding("utf-8");  HttpSession sesson=request.getSession();   PrintWriter out=response.getWriter();   String str=(String)sesson.getAttribute("prog")+"";  String res=(String)sesson.getAttribute("result");  String err=(String)sesson.getAttribute("error");  System.out.println(str+","+res+","+err);  out.print(str+","+res+","+err);  out.flush();  out.close(); }}

效果圖如下:

 

以上就是本文的全部內容,希望對大家有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产小视频91| 国产成人精品网站| 亚洲成人网久久久| 久久综合免费视频| 国产日韩在线看| 91在线看www| 欧美精品国产精品日韩精品| 日韩电影网在线| 亚洲视频第一页| 亚洲欧美日韩中文在线制服| 欧洲亚洲在线视频| 亚洲国产99精品国自产| 亚洲 日韩 国产第一| 欧美日韩中文字幕在线视频| 国产这里只有精品| 日韩免费视频在线观看| 亚洲理论电影网| 国产精品丝袜视频| 国产精品中文久久久久久久| 91久热免费在线视频| 日韩精品日韩在线观看| 久久777国产线看观看精品| 色综合五月天导航| 亚洲sss综合天堂久久| 51午夜精品视频| 26uuu亚洲国产精品| 国产欧美在线观看| 日韩国产在线播放| 国产精品私拍pans大尺度在线| 91超碰caoporn97人人| 97国产真实伦对白精彩视频8| 国产精品91久久久久久| 亚洲国产精品成人av| 久久久免费观看视频| 日本不卡高字幕在线2019| 亚洲视频欧美视频| 久久久成人精品| 国产女同一区二区| 国产91色在线|免| 欧美激情手机在线视频| 国产欧美精品久久久| 欧美成人午夜激情在线| 久久国产一区二区三区| 亚洲黄一区二区| 中文字幕视频一区二区在线有码| 国产视频欧美视频| 中文字幕av一区二区| 国产黑人绿帽在线第一区| 国产美女91呻吟求| 欧洲精品在线视频| 国产精品视频1区| 欧美视频一区二区三区…| 久久精品一本久久99精品| 成人久久精品视频| 国产成人一区二区三区电影| 国产精品国产三级国产专播精品人| 欧美理论在线观看| 欧美成人免费全部观看天天性色| 欧美国产日韩xxxxx| 久精品免费视频| 国产日韩欧美日韩大片| 国产99视频精品免视看7| 亚洲综合中文字幕在线| 亚洲全黄一级网站| 国产成+人+综合+亚洲欧洲| 91国产美女在线观看| 欧美日韩美女在线观看| 亚洲福利精品在线| 久久99精品国产99久久6尤物| 成人精品福利视频| 在线播放国产一区二区三区| 亚洲免费电影在线观看| 欧美激情videos| 欧美日韩在线另类| 日韩免费不卡av| 亚洲视频综合网| 国外视频精品毛片| 青青草精品毛片| 欧美一区二区.| 热久久免费视频精品| 中文字幕一精品亚洲无线一区| 日韩欧美在线视频观看| 狠狠躁18三区二区一区| 亚洲国产精品va在线看黑人| 精品亚洲国产成av人片传媒| 欧美一级片在线播放| 欧美成人免费全部观看天天性色| 日韩精品在线播放| 成人免费直播live| 亚洲热线99精品视频| 热久久免费视频精品| 97久久精品视频| 久久久伊人欧美| 2019亚洲男人天堂| 色综合久久88| 国产精品久久久久久久9999| 福利一区视频在线观看| 国产精品9999| 国产啪精品视频网站| 国内精品久久久久久| 亚洲石原莉奈一区二区在线观看| 中文字幕亚洲字幕| 亚洲香蕉av在线一区二区三区| 欧美精品免费在线观看| 亚洲激情电影中文字幕| 欧美福利视频网站| 亚洲欧美日韩中文在线| 亚洲全黄一级网站| 日韩电影中文字幕在线观看| 欧美老女人xx| 亚洲女人天堂视频| 成人中心免费视频| 91精品久久久久久久久久入口| 国产99在线|中文| 6080yy精品一区二区三区| 亚洲精品大尺度| 亚洲少妇激情视频| 成人情趣片在线观看免费| 亚洲精品日产aⅴ| 国产精品美女主播在线观看纯欲| 久久综合久久八八| 中文字幕精品一区久久久久| 92国产精品视频| 欧美日韩国产在线| 亚洲精品97久久| 日韩在线免费av| 欧美乱大交做爰xxxⅹ性3| 欧美日韩亚洲系列| 亚洲精品视频播放| 日韩欧美成人区| 国产精品自产拍在线观看| 91免费福利视频| 91精品国产高清久久久久久| 日本免费在线精品| 亚洲视频在线观看网站| 亚洲成年人在线| 日韩欧美在线中文字幕| 亚洲综合在线中文字幕| 久久成年人免费电影| 亚洲欧美日韩高清| 精品自拍视频在线观看| 91久久夜色精品国产网站| 久久精品亚洲国产| 68精品久久久久久欧美| 欧美日韩第一页| 欧美性20hd另类| 日本久久亚洲电影| 亚洲区免费影片| 国产精品999999| 成人精品久久一区二区三区| 中文字幕综合一区| 亚洲人成网站色ww在线| 欧美性猛交xxxx乱大交| 欧美—级高清免费播放| 成人在线国产精品| 欧美大片在线看免费观看| 亚洲欧洲xxxx| 在线成人中文字幕| 91香蕉嫩草影院入口| 国产精品第3页| 青青久久av北条麻妃海外网| 最近2019中文字幕一页二页| 欧美一区视频在线| 91视频国产高清|