Reputation: 4721
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
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
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:
.
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: \\
'\\.('
becomes \.(
in memoryRegExp
constructor indicates case-insensitivityIf 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:
^
'[\\/\\\\][a-z0-9...
Upvotes: 0
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