Chrome扩展程序:如何列出本地目录的内容

时间:2012-07-12 13:20:20

标签: google-chrome google-chrome-extension filesystems google-chrome-os

我想做什么:

我想为测试目的创建Chrome扩展程序。该扩展程序应该能够访问本地硬盘上的目录和文件。

我是怎么做到的:

我在file:///*文件中请求manifest.json的权限。然后我确保复选了Allow access to file URLs复选框。然后我为一个文件做了一个XHR:

  var xhr = new XMLHttpRequest();  
  xhr.open("GET", 'file://c:/dir/file.name', true);     
  xhr.onload = function(e) {  
      console.log('response: ', xhr.response);
  }  
  xhr.send();

...和整个目录的XHR:

  var xhr = new XMLHttpRequest();  
  xhr.open("GET", 'file://c:/dir/', true);     
  xhr.onload = function(e) {  
      console.log('response: ', xhr.response);
  }  
  xhr.send();

...以及 total 文件系统:

  var xhr = new XMLHttpRequest();  
  xhr.open("GET", 'file:///', true);     
  xhr.onload = function(e) {  
      console.log('response: ', xhr.response);
  }  
  xhr.send();

发生了什么:

  • 我能够为我的文件请求获得​​正确的回复。
  • 当我请求目录时,我收到了Chrome的源代码 默认的人类可读目录概述:

  <html>
  <head>
  <script>

[...]

  </script>
  <style>

[...]

  </style>
  <title id="title"></title>
  </head>
  <body>
  <div id="listingParsingErrorBox" i18n-values=".innerHTML:listingParsingErrorBoxText"></div>
  <span id="parentDirText" style="display:none" i18n-content="parentDirText"></span>
  <h1 id="header" i18n-content="header"></h1>
  <table id="table">
    <tr class="header">
      <td i18n-content="headerName"></td>
      <td class="detailsColumn" i18n-content="headerSize"></td>
      <td class="detailsColumn" i18n-content="headerDateModified"></td>
    </tr>
  </table>
  </body>
  </html>

[...]

  <script>start("C:\\dir\\");</script>
  <script>addRow("..","..",1,"0 B","11/11/11 11:11:11 AM");</script>
  <script>addRow("file.name","file.name",0,"4.9 kB","11/11/11 11:11:11 PM");</script>
  • 当我请求整个文件系统时,我收到了一个错误。

我的问题:

我能读懂简单的文件。但是,我的扩展如何获得一个很好的机器可读的目录或整个文件系统的概述?感谢。

编辑: 我知道FileSystem API旨在访问沙盒filesystem://,但Chrome也允许扩展程序访问file:// 。我找不到任何与Chrome扩展程序file://访问权限相关的文档,因此我只能猜测。

1 个答案:

答案 0 :(得分:3)

独立Chrome中没有内置功能。

解析目录列表页面的替代方法:

  1. NPAPI扩展(C ++,推荐)
  2. 具有文件系统访问权限的本地服务器。 NodeJS is a good pick