2016-04-08 43 views
1

在表單中有多個文件輸入現在我必須檢查每個文件輸入的zip文件不包含任何無效文件(doc,docx和pdf只允許)。zip.js讀取zip內的文件名。 (僅限客戶端腳本)

我寫

<script src="https://code.jquery.com/jquery-2.2.1.js" integrity="sha256-eNcUzO3jsv0XlJLveFEkbB8bA7/CroNpNVk3XpmnwHc=" crossorigin="anonymous"></script>  
<script type="text/javascript" src="/js/zip.js"/> 
<script type="text/javascript" src="/js/inflate.js"/> 
<script type="text/javascript" src="/js/deflate.js"/> 
<script type="text/javascript" src="/js/z-worker.js"/> 
<script type="text/javascript"> 
    $(document).ready(function() { 
     if((window.location.href.indexOf("LibraryItemUpload`1&ParentId=7d428470-2234-41c0-85f4-a512d51198c6") > -1) || (window.location.href.indexOf("LibraryItemUpload%601&ParentId=7d428470-2234-41c0-85f4-a512d51198c6") > -1)) 
     { 
      $("input:file").change(function() { 
       var regex=new RegExp("^[A-Za-z0-9 ]+$"); 
       var file=this.files[0]; 
       var key = this.value; 
       var ze = key.split('\\').pop(); 
       var filename = ze.split('.')[0]; 
       var extension=key.split('.').pop().trim().toLowerCase(); 
       if(extension == 'zip') 
       {    
        zip.createReader(new zip.BlobReader(file), function(reader) { 

         // get all entries from the zip 
         reader.getEntries(function(entries) { 
         if (entries.length) { 

          // get first entry content as text 
          entries[0].getData(new zip.TextWriter(), function(text) { 
          // text contains the entry data as a String 
          console.log(text); 

          // close the zip reader 
          reader.close(function() { 
           // onclose callback 
          }); 

          }, function(current, total) { 
          // onprogress callback 
          }); 
         } 
         }); 
        }, function(error) { 

        }); 
       } 
       if (!regex.test(filename)) {     
        alert('Please do not use special characters in file name please rename file name and upload it again.'); 
        location.reload(); 
       } 
       else { 
        return true; 
       } 
      }); 
     } 
    }); 
    </script> 

並寫入代碼從zip.js讀取文件名,但流動doen't去zip.createReader功能。

請給我建議,如果另一個JavaScript可用於讀取zip文件,我只想要條目對象讀取文件名。

+0

你的代碼看起來不完整,請給我們更多的代碼和你得到的錯誤描述。你有沒有檢查zip.js文件,其中包含郵件列表條目的信息? -https://gildas-lormeau.github.io/zip.js/core-api.html#zip-reading-example – majita

回答

0
function readEntries(entries) { 
    var entryLength = entries.length; 
    for (i = 0; i < entryLength; i++) { 
     var entry = entries[i]; 
     var fileName = entry.filename.substring(entry.filename.lastIndexOf("/") + 1); //if inside folder 
     var ext = fileName.split(".").pop().toLowerCase(); 
     if (ext.toUpperCase() == 'DOC' || ext.toUpperCase() == 'PDF' || 
      ext.toUpperCase() == 'DOCX') { 
      //logic 
     } 
    } 
} 

zip.useWebWorkers = false;//explicitly include (required) zip-workers ['zip.js','zip-fs.js','z-worker.js','inflate.js','deflate.js'] 

var fileInput = document.getElementById("zipfile");//Input File 
fileInput.addEventListener('change', function(event) { 
    zip.createReader(new zip.BlobReader(fileInput.files[0]), function(zipReader) { 
     zipReader.getEntries(readEntries); 
    }, function (error) { 
     console.log(error); 
    }); 
}); 

我還沒有測試過這段代碼,但我以前用過類似的邏輯。