HEEN
HEEN

Reputation: 4721

Validation for file extension is not checking properly in jquery

I have written a validation for excepting files which has extension of .xls and .xlsx So here is the code below.

function isFileValid() {
            var allowedFiles = [".xlsx", ".xls"];
            //  var allowedFiles = [".xls"];
            var fileUpload = document.getElementById("MainContent_fluploadData");
            var fileChanged = fileUpload.value !== window.lastUploadedFilename;
            window.lastUploadedFilename = fileUpload.value;
            var regex = new RegExp("([a-zA-Z0-9\s_\\.\-:])+(" + allowedFiles.join('|') + ")$");

            if (!regex.test(fileUpload.value.toLowerCase()) && fileUpload.value !== '') {
                alert("Please upload files having extensions: " + allowedFiles.join(', ') + " only.");
                $('#MainContent_fluploadData').val('');
                return false;
            }
 }

So even if I am uploading valid excel file whose name is like :- SITE_ADDITION (1).xlsx

Please suggest.

Upvotes: 1

Views: 568

Answers (3)

Mitali Patel
Mitali Patel

Reputation: 427

<html>
    <head>
        <title>Validation for file extension is not checking properly in jquery</title>
        <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
    </head>
    <body>
      <input type="file" name="file_input" id="file_input">
      <script>
           $("#file_input").change(function () {
              var fileExtension = ['xlsx', 'xls'];
              if ($.inArray($(this).val().split('.').pop().toLowerCase(), fileExtension) == -1){
                 alert("Invalid file type");
                 $(this).val('');
                 return false;
              }
              
          });
      </script>
    </body>
</html>

Upvotes: 1

Peter Thoeny
Peter Thoeny

Reputation: 7616

If you are only concerned about the extension use this:

function isFileValid() {
    var allowedFiles = [".xlsx", ".xls"];
    var fileUpload = document.getElementById("MainContent_fluploadData");
    window.lastUploadedFilename = fileUpload.value;
    var regex = new RegExp('\\.(' + allowedFiles.join('|') + ')$', 'i');
    if (!regex.test(fileUpload.value)) {
        alert("Please upload files having extensions: " + allowedFiles.join(', ') + " only.");
        $('#MainContent_fluploadData').val('');
        return false;
    }
}

Notes:

  • you don't need to check for characters leading up to the . if you don't care about the chars in the file name, as long as you do not anchor the regex at the beginning.
  • '\\.(' - if you define a string and want to have a literal backslash you need to escape it: \\
    • in other words, string definition '\\.(' becomes \.( in memory
  • the second parameter to the RegExp constructor indicates case-insensitivity

If on the other hand you want to restrict the characters in the filename, use this:

function isFileValid() {
    var allowedFiles = [".xlsx", ".xls"];
    var fileUpload = document.getElementById("MainContent_fluploadData");
    window.lastUploadedFilename = fileUpload.value;
    var regex = new RegExp('^[a-z0-9\\s_\\.\\-:\\(\\)]+\\.(' + allowedFiles.join('|') + ')$', 'i');
    if (!regex.test(fileUpload.value)) {
        alert("Please upload file with only A-Z, 0-9, space, dot, dash, :, () in name, and extension: " + allowedFiles.join(', '));
        $('#MainContent_fluploadData').val('');
        return false;
    }
}

Notes:

  • the regex needs to be anchored at the beginning with ^
  • tweak the character class as needed for allowed chars
  • on the other hand, in case you have to full path name in your filename, start the regex string with: '[\\/\\\\][a-z0-9...

Upvotes: 0

Negi Rox
Negi Rox

Reputation: 3922

If you are looking for regEx please use the below regex for your code.

var regEx = new RegExp("^.*\.xls[xm]?$");//reg ex for excel file

console.log(regEx.test("abc.xlsx"));// true
console.log(regEx.test("abc.xls"));//true
console.log(regEx.test("abc.xlsm"));//true
console.log(regEx.test("abc.xlst"));//false
console.log(regEx.test("abc.doc"));//false
console.log(regEx.test("SITE_ADDITION (1).xlsx"));//true

Upvotes: 0

Related Questions