DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> 真正好用的js驗證上傳文件大小的簡單方法
真正好用的js驗證上傳文件大小的簡單方法
編輯:關於JavaScript     

最近使用到一個文件上傳功能,發現惡意上傳一個2G文件時,後台處理響應較慢,遂想到能否使用js來進行客戶端的驗證。但查閱網上多處資料,均使用 ActiveXObject("Scripting.FileSystemObject"); 的方法,該方法需要將Internet選項中安全級別提高,啟用一個系統本身不推薦的選項,會出現如下非常不友好的提示:

所以這邊並沒有用到,而是尋求其他方法。

這邊新的思路是img標簽中的dynsrc屬性。

在FireFox、Chrome浏覽器中可以根據document.getElementById(“id_file”).files[0].size 獲取上傳文件的大小(字節數),而IE浏覽器中不支持該屬性,只能借助<img>標簽的dynsrc屬性,來間接實現獲取文件的大小(但需要同意ActiveX控件的運行,但是不會引起上面的不友好、不安全的提示)。

具體方法如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> 
<html xmlns="http://www.w3.org/1999/xhtml"> 
  <head> 
  <meta name="DEscription" contect="my code demo" /> 
  <meta name="Author" contect="[email protected]" /> 
  <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
  <title>js check file size @ www.micmiu.com</title> 
  </head> 
  <body> 
    <img id="tempimg" dynsrc="" src="" style="display:none" /> 
    <input type="file" name="file" id="fileuploade" size="40" /> 
    <input type="button" name ="check" value="checkfilesize" onclick="checkfile()"/> 
 
  </body> 
  <script type="text/javascript"> 
    var maxsize = 2*1024*1024;//2M 
    var errMsg = "上傳的附件文件不能超過2M!!!"; 
    var tipMsg = "您的浏覽器暫不支持計算上傳文件的大小,確保上傳文件不要超過2M,建議使用IE、FireFox、Chrome浏覽器。"; 
    var browserCfg = {}; 
    var ua = window.navigator.userAgent; 
    if (ua.indexOf("MSIE")>=1){ 
      browserCfg.ie = true; 
    }else if(ua.indexOf("Firefox")>=1){ 
      browserCfg.firefox = true; 
    }else if(ua.indexOf("Chrome")>=1){ 
      browserCfg.chrome = true; 
    } 
    function checkfile(){ 
      try{ 
        var obj_file = document.getElementById("fileuploade"); 
        if(obj_file.value==""){ 
          alert("請先選擇上傳文件"); 
          return; 
        } 
        var filesize = 0; 
        if(browserCfg.firefox || browserCfg.chrome ){ 
          filesize = obj_file.files[0].size; 
        }else if(browserCfg.ie){ 
          var obj_img = document.getElementById('tempimg'); 
          obj_img.dynsrc=obj_file.value; 
          filesize = obj_img.fileSize; 
        }else{ 
          alert(tipMsg); 
        return; 
        } 
        if(filesize==-1){ 
          alert(tipMsg); 
          return; 
        }else if(filesize>maxsize){ 
          alert(errMsg); 
          return; 
        }else{ 
          alert("文件大小符合要求"); 
          return; 
        } 
      }catch(e){ 
        alert(e); 
      } 
    } 
  </script> 
</html> 

以上就是小編為大家帶來的真正好用的js驗證上傳文件大小的簡單方法全部內容了,希望大家多多支持~

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved