如何上传html验证文件大小,真正好用的js验证上传文件大小的简单方法

最近使用到一个文件上传功能,发现恶意上传一个2G文件时,后台处理响应较慢,遂想到能否使用js来进行客户端的验证。但查阅网上多处资料,均使用 ActiveXObject("Scripting.FileSystemObject"); 的方法,该方法需要将Internet选项中安全级别提高,启用一个系统本身不推荐的选项,会出现如下非常不友好的提示:

4417dfda215b3a27e02c04a6f3a18d8f.png

所以这边并没有用到,而是寻求其他方法。

这边新的思路是img标签中的dynsrc属性。

在FireFox、Chrome浏览器中可以根据document.getElementById(“id_file”).files[0].size 获取上传文件的大小(字节数),而IE浏览器中不支持该属性,只能借助标签的dynsrc属性,来间接实现获取文件的大小(但需要同意ActiveX控件的运行,但是不会引起上面的不友好、不安全的提示)。

具体方法如下:

js check file size @ www.micmiu.com

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);

}

}

以上就是小编为大家带来的真正好用的js验证上传文件大小的简单方法全部内容了,希望大家多多支持脚本之家~

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值