jQuery-Validation-Engine - 验证文件MIME类型

时间:2013-06-13 21:04:39

标签: jquery-validation-engine

我想使用jQuery-Validation-Engine来验证文件输入的MIME类型。我怎么能这样做?

我的方法是这样的:

function checkMIME(field, rules, i, options){
    var file = $("#userfile")[0].files[0];
    var MimeFilter = /^(image\/bmp|image\/gif|image\/jpeg|image\/png|image\/tiff)$/i;
    if (! MimeFilter.test(file.type)) {
     return options.allrules.validate2fields.alertText;
  }
}

感谢名单 Kashuda

4 个答案:

答案 0 :(得分:7)

好的,通过将这些行添加到query.validationEngine-LANG.js

找到了解决方案
"validateMIME":  {
    "func": function(field, rules, i, options){
   //add to input tag: data-validation-engine="validate[required, custom[validateMIME[image/jpeg|image/png]]]"

    var fileInput = field[0].files[0];
    var MimeFilter = new RegExp(rules[3],'i');

    if (fileInput) {
        return MimeFilter.test(fileInput.type);
    } else { return true;}
  },
"alertText": "* Wrong Mime Type."

},

答案 1 :(得分:5)

通过修改代码,我实现了另一种验证文件MIME类型的方法:

首先将以下代码附加到jquery.validationEngine.js文件的'_validateField'方法中

case "checkFileType":
errorMsg = methods._checkFileType(field, rules, i, options);
break;

然后将以下代码附加到同一个文件

_checkFileType: function (field, rules, i, options) {
        var uploadedFile = $(field);
        if (uploadedFile) {
            var extensions = rules[i + 1];               
            var mimeFilter = new RegExp(extensions);
            if (!mimeFilter.test($(uploadedFile).val().split('.').reverse()[0])) {
                return options.allrules.checkFileType.alertText;
            }
        }
        else {
            return true;
        }            
    },

最后, 将以下行附加到jquery.validationEngine-en.js文件

"checkFileType": {
                    "regex": "none",
                    "alertText": "* Wrong file Type."                    
                },

用法:

<input type="file" name="file" id="myfile" class="validate[checkFileType[jpg|jpeg|gif|JPG|png|PNG]]"/>

答案 2 :(得分:0)

如果图像不是必需的,只需将其添加到jquery.validationEngine.js选项添加到输入标记:

    <div >
                ......>
        <?= $content ?>
    </div>

如果是必填字段,则添加

添加到输入标记:

class="validate[optional, custom[validateMIME[image/jpeg|image/png]]]" 

答案 3 :(得分:0)

这对我有用

在表单字段

class="validate[required], custom[validateMIME[pdf|doc|docx]" 

在query.validationEngine-LANG.js

"validateMIME": {   

    "func": function(field, rules, i, options){
            var uploadedFile = $(field);  

            if (uploadedFile) {
            var extensions = rules[i+2];               
            var mimeFilter = new RegExp(extensions);                     

            return (mimeFilter.test($(uploadedFile).val().split('.').reverse()[0])) ? true : false;
            }                      

     },                        
 "alertText": "Wrong File Extension"
 },