Estou tentando fornecer uma solução somente de script para ler o conteúdo de um arquivo em uma máquina cliente por meio de um navegador.
Tenho uma solução que funciona com Firefox e Internet Explorer. Não é bonito, mas estou apenas tentando coisas no momento:
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 :(";
}
}
Posso ligar getFileContents()
e ele escreverá o conteúdo na fileContents
área de texto.
Existe uma maneira de fazer isso em outros navegadores?
Estou mais preocupado com o Safari e o Chrome no momento, mas estou aberto a sugestões para qualquer outro navegador.
Edit: Em resposta à pergunta "Por que você deseja fazer isso?":
Basicamente, quero fazer o hash do conteúdo do arquivo junto com uma senha de uso único no lado do cliente para que possa enviar essas informações de volta como uma verificação.
fonte
Respostas:
Editado para adicionar informações sobre a API File
Desde que escrevi esta resposta originalmente, a API de arquivo foi proposta como padrão e implementada na maioria dos navegadores (a partir do IE 10, que adicionou suporte para a
FileReader
API descrita aqui, embora ainda não seja aFile
API). A API é um pouco mais complicada do que a API Mozilla mais antiga, pois foi projetada para suportar a leitura assíncrona de arquivos, melhor suporte para arquivos binários e decodificação de diferentes codificações de texto. Há alguma documentação disponível na Mozilla Developer Network , bem como vários exemplos online. Você o usaria da seguinte maneira:Resposta original
Não parece haver uma maneira de fazer isso no WebKit (portanto, Safari e Chrome). As únicas chaves que um objeto File possui são
fileName
efileSize
. De acordo com a mensagem de confirmação para o suporte File e FileList, eles são inspirados no objeto File do Mozilla , mas parecem oferecer suporte a apenas um subconjunto dos recursos.Se você quiser mudar isso, pode sempre enviar um patch para o projeto WebKit. Outra possibilidade seria propor a API Mozilla para inclusão no HTML 5 ; a lista de discussão WHATWG é provavelmente o melhor lugar para fazer isso. Se você fizer isso, é muito mais provável que exista uma maneira cross-browser de fazer isso, pelo menos em alguns anos. Claro, enviar um patch ou uma proposta para inclusão no HTML 5 significa algum trabalho defendendo a ideia, mas o fato de o Firefox já implementá-lo dá a você algo para começar.
fonte
Para ler um arquivo escolhido pelo usuário, usando uma caixa de diálogo de abertura de arquivo, você pode usar a
<input type="file">
tag. Você pode encontrar informações sobre ele no MSDN . Quando o arquivo é escolhido, você pode usar a API FileReader para ler o conteúdo.fonte
Boa codificação!
Se você receber um erro no Internet Explorer, altere as configurações de segurança para permitir ActiveX
fonte