当前位置: 首页 > 面试题库 >

在各种浏览器中使用javascript在客户端读取文件内容

莘聪
2023-03-14
问题内容

我试图提供一种仅脚本解决方案,用于通过浏览器读取客户端计算机上文件的内容。

我有一个可与Firefox和Internet Explorer一起使用的解决方案。它不是很漂亮,但是我现在只是在尝试:

function getFileContents() {
    var fileForUpload = document.forms[0].fileForUpload;
    var fileName = fileForUpload.value;

    if (fileForUpload.files) {
        var fileContents = fileForUpload.files.item(0).getAsBinary();
        document.forms[0].fileContents.innerHTML = fileContents;
    } else {
        // try the IE method
        var fileContents = ieReadFile(fileName);
        document.forms[0].fileContents.innerHTML = fileContents;
    }
}

function ieReadFile(filename) 
{
    try
    {
        var fso  = new ActiveXObject("Scripting.FileSystemObject"); 
        var fh = fso.OpenTextFile(filename, 1); 
        var contents = fh.ReadAll(); 
        fh.Close();
        return contents;
    }
    catch (Exception)
    {
        return "Cannot open file :(";
    }
}

我可以打电话getFileContents(),它将内容写入fileContents文本区域。

有其他浏览器可以做到这一点吗?

目前,我最关心的是Safari和Chrome浏览器,但是我愿意接受其他任何浏览器的建议。

编辑: 回答问题,“为什么要这样做?”:

基本上,我想在客户端对文件内容和一次性密码进行哈希处理,以便我可以将此信息发回作为验证。


问题答案:

编辑以添加有关File API的信息

自从我最初写这个答案以来,文件API就已经被提议作为标准并在大多数浏览器中实现(从IE10开始,它增加了FileReader对此处描述的API的支持,尽管还不是FileAPI)。该API比较旧的MozillaAPI稍微复杂一点,因为它旨在支持文件的异步读取,对二进制文件的更好支持以及对不同文本编码的解码。Mozilla开发人员网络上有一些可用的文档,以及各种在线示例。您将按以下方式使用它:

var file = document.getElementById("fileForUpload").files[0];
if (file) {
    var reader = new FileReader();
    reader.readAsText(file, "UTF-8");
    reader.onload = function (evt) {
        document.getElementById("fileContents").innerHTML = evt.target.result;
    }
    reader.onerror = function (evt) {
        document.getElementById("fileContents").innerHTML = "error reading file";
    }
}

原始答案

在WebKit中(似乎是Safari和Chrome)似乎没有办法做到这一点。File对象具有的唯一键是fileNamefileSize。根据支持File和FileList的提交消息,这些是受Mozilla的File对象启发的,但它们似乎仅支持部分功能。

如果您想更改此设置,则始终可以将补丁发送到WebKit项目。另一种可能性是建议将Mozilla
API包含在HTML 5中。在WHATWG的邮件列表是可能做到这一点的最好的地方。如果这样做,那么至少在几年后,很有可能会有跨浏览器的方式来做到这一点。当然,提交修补程序或提案以包含在HTML5中确实意味着捍卫该想法的一些工作,但是Firefox已经实现它的事实为您提供了一些起点。



 类似资料:
  • 问题内容: 我想知道是否可以创建文本文件并将其保存在使用javascript的用户“下载”部分中。我的功能的工作方式是当用户单击“提交”按钮时,我将用户信息填充到文本文件中,然后将其保存在他的计算机中。我想这在谷歌浏览器中工作。 这可能吗?我看到过一些帖子专门告诉我这是一个严重的安全问题。 问题答案: window.requestFileSystem = window.requestFileSys

  • 本文向大家介绍JavaScript中的document.referrer在各种浏览器测试结果,包括了JavaScript中的document.referrer在各种浏览器测试结果的使用技巧和注意事项,需要的朋友参考一下 前段时间需要通过 JavaScript 获取页面的来源,这个操作很简单,使用 document.referrer 就可以获取到了。不过,实际应用中还是有很多意外情况,这儿简单整理一

  • 本文向大家介绍php实现读取手机客户端浏览器的类,包括了php实现读取手机客户端浏览器的类的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了php实现读取手机客户端浏览器的类。分享给大家供大家参考。具体分析如下: 这里介绍的手机信息函数类有取手机号码,浏览器报头信息,取得手机类型,取得手机IP等功能。 希望本文所述对大家的php程序设计有所帮助。

  • 我对硒很陌生。我开发了一个应用程序,使用一个selenium web驱动程序来做网页上的一些动作。当我在本地运行时,它可以很好地工作,也就是说,它在我的机器中启动了一个浏览器。我在VM服务器上部署了这个应用程序,所以脚本在服务器上运行(在VM Ware机器中启动的浏览器),而不是在客户端。谁能帮助我如何在客户端启动浏览器?

  • 问题内容: 是否有从客户端浏览器获取时区的可靠方法?我看到了以下链接,但我想要一个更强大的解决方案。 使用JavaScript自动检测时区 JavaScript中的时区检测 问题答案: 查看此存储库pageloom很有帮助 下载jstz.min.js并将功能添加到您的html页面 然后从您的显示代码调用此函数

  • 一面-2023年5月6日 ios客户端,大前端、object-c 自我介绍。有点背稿的感觉。 聊一个项目。说了OSG的项目。提到内存管理。 开始八股。内存:只能指针。 多态,静态、动态。模板、虚函数。静态的除了模板还有啥。析构函数为什么要添加虚函数。 空类size的大小。 struct/class的区别。 堆/栈/BSS几个内存类别 TCP四次挥手。 ipv4地址空间这么小怎么够用,NAT。用同一