bootstrap fileinput.js扩展-增加对文件名特殊字符过滤

在项目中使用 bootstrap fileinput.js作为文件上传插件的过程中,需求提出如果文件名中包含某些特殊字符,例如¥、#等,则不允许用户上传此类文件。 fileinput.js本身并不支持文件名的过滤,因此考虑对其进行扩展。具体如下:

修改 fileinput.js源代码:

$.fn.fileinput.defaults中增加 notallowedFilenameExtensions:null,即初始化可配置限制的字符有哪些;

_readFiles方法中增加具体的判断,如下:

var self 时,增加 filenameExt=self.notallowedFilenameExtensions,//获取初始化时定义的特殊字符

readFile=function(i) {}中增加如下内容

//当定义的特殊字符不为空时,增加对文件名中是否包含特殊字符的判断

if(!$h.isEmpty(filenameExt))

{

var filenamecheck=newRegExp(filenameExt.join('|'),'igm');

var checkresult=file.name.match(filenamecheck);

if(checkresult)

{

var pipeizifu=checkresult.join(',');

msg="文件名包含特殊字符"+pipeizifu+";请去掉后再次上传";

throwError(msg,file,previewId, i);

return;

}

}

在初始化fileinput时,

$("#file-0").fileinput({

fileActionSettings:{showUpload:false,showZoom:false},

language:'zh',

showUpload:true,

showRemove:false,

uploadExtraData: {fileUseage:'0',taskType:'0'},

uploadAsync:false,//采用同步上传

uploadUrl:'faceDetect/uploadPhoto',// you must set a valid URL here else you will get an error

/*uploadExtraData:{id: 100, value: '100 Details'},*/

allowedFileExtensions: ['jpg','png','bmp','jpeg'],

notallowedFilenameExtensions:['#','%','¥','@'],//文件名中不允许出现的字符

overwriteInitial:false,

msgFilesTooMany:"选择上传的文件数量({n})超过允许的最大数值{m}!",

dropZoneTitle:"选择目标图片,图片大小不超过2MB",

maxFileSize:2000,//单位为kb,如果为0表示不限制文件大小

maxFileCount:1

}

});

效果如下:


9531544-e506df1a11624203.png
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 176,308评论 25 709
  • 点击查看原文 Web SDK 开发手册 SDK 概述 网易云信 SDK 为 Web 应用提供一个完善的 IM 系统...
    layjoy阅读 14,767评论 0 15
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,107评论 19 139
  • 经常会听到女生说,以后要找个男朋友,教她游泳,带她攀岩,给她弹吉他,牵着她一起去流浪,光是听着就很浪漫。可是姑娘,...
    沉默群像阅读 3,157评论 0 1
  • 关于职业规划? 职场老人最看重的三点是「积极的职业态度」「专业知识和技能」以及「良好的职业习惯」。相比较而言,新人...
    王兵阅读 1,801评论 0 2

友情链接更多精彩内容