国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

真正好用的js驗證上傳文件大小的簡單方法

2019-11-20 08:39:17
字體:
來源:轉載
供稿:網友

最近使用到一個文件上傳功能,發現惡意上傳一個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="Michael@www.micmiu.com" />   <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驗證上傳文件大小的簡單方法全部內容了,希望大家多多支持武林網~

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 徐水县| 屏山县| 岫岩| 犍为县| 腾冲县| 文水县| 定兴县| 松阳县| 德州市| 淮阳县| 磐安县| 淮安市| 泊头市| 大名县| 福泉市| 三都| 诸城市| 东乌| 常宁市| 康平县| 赫章县| 张家口市| 华阴市| 阳城县| 堆龙德庆县| 古丈县| 琼结县| 龙里县| 荆门市| 高密市| 呼玛县| 垣曲县| 马公市| 内黄县| 芷江| 鞍山市| 宿松县| 灵山县| 高碑店市| 辽宁省| 忻州市|