Como isso é possível não é um caractere ascii, é codificado com 3 bytes, 0xE881B5. O que eu esperava é obter u0081 porque ascii caracteres são codificados com um único byte. Se eu ler usando a codificação binária imprime verdadeiro, o que eu espero com a codificação ascii. Este resultado é uma característica intencional Se ascii codificação retorna o mesmo resultado como utf8 codificação então por que é ascii um possível parâmetro Este é o conteúdo (aberto com programa HxD): A resposta rápida é que o nó não faz qualquer mágica ao converter de um buffer para Uma string, se é ascii ou utf8. Sua string utf8 é totalmente inválida ascii. Então eu acho que idealmente iria lançar um erro, mas obviamente não. Eu não esperaria o u0081 desde que é inválido ascii. Você pode ver na fonte do Nó. O código para converter de um buffer para uma seqüência de caracteres são o. Funções de fatia. As funções ascii e utf8 são idênticas, levando ao comportamento que você está vendo. Esses construtores não fazer nada extravagante, eles apenas tomar uma seqüência de bytes e convertê-lo em uma Cadeia de caracteres JS, assumindo que é válido nessa codificação. As diferenças entre as duas codificações vêm das funções AsciiWrite e Utf8Write nesse arquivo, que tratam as coisas de maneira diferente. Como você viu a partir de seus testes, ajustes binários melhor com o que você está procurando. Binário passa por cada byte individual em um buffer e retorna uma seqüência onde cada ponto de código tem esse valor de byte. Sem saber exatamente qual idioma que é, eu estou adivinhando japonês (me corrija se eu estiver errado). No entanto, Shift JIS tem a infeliz propriedade de que muitas vezes quebra qualquer analisador (software que lê o texto codificado) que não é projetado especificamente Para lidar com isso. Por exemplo, um método de pesquisa de texto pode obter falso hits se ele não foi projetado para Shift JIS. EUC, por outro lado, é tratado muito melhor por analisadores que foram escritos para 7 bits ASCII (e, portanto, EUC codificações são utilizadas no UNIX, onde grande parte do arquivo de manipulação de código foi historicamente escrito apenas para codificações Inglês). Mas a EUC não é compatível com o JIS X 0201, a primeira codificação japonesa principal. Outras complicações surgem porque os padrões originais de e-mail da Internet só suportam protocolos de transferência de 7 bits. Assim, a codificação JIS foi desenvolvida para enviar e receber e-mails. Em padrões de conjunto de caracteres, como JIS, nem todos os caracteres necessários são incluídos, então gaiji (caracteres externos) às vezes são usados para complementar o conjunto de caracteres. Gaiji pode vir na forma de pacotes de fonte externa, onde os caracteres normais foram substituídos por novos caracteres, ou os novos caracteres foram adicionados às posições de caracteres não utilizados. No entanto, gaiji não são práticos em ambientes Internet, uma vez que o conjunto de fontes deve ser transferido com texto para usar o gaiji. Como resultado, esses caracteres são escritos com caracteres semelhantes ou mais simples no local, ou o texto pode precisar ser escrito usando um conjunto de caracteres maior (como Unicode) que oferece suporte ao caractere necessário. Gostaria de tentar com alguns personagens mais exóticos, como o seu teste irá falhar. Respondeu Dec 14 12 at 13:39 Isso doesn39t resposta porque nó decodifica o arquivo como utf8 enquanto explicitamente disse para decodificá-lo como ascii. O comportamento esperado é um erro, como 0xe8 está fora gama ascii. Ndash Deestan Dec 14 12 at 13:43 Deestan Onde na sua pergunta original você disse algo sobre utf8 A menos que eu esteja faltando algo e binário utf8 ndash Woot4Moo 14 de dezembro às 13: 45Nexe Nexe é um utilitário de linha de comando que compila seu nó. Js em um único arquivo executável. Motivação Capacidade de executar vários aplicativos com diferentes tempos de execução node. js. Binários distribuíveis sem necessidade de nó / npm. Inicia mais rápido. Lockdown versões de aplicativos específicos, e facilmente reversão. Implementações mais rápidas. Requisitos de Construção Linux / Mac / BSD / Windows Python 2.6 ou 2.7 (use --python se não estiver em PATH) Windows: Visual Studio 2010 Caveats Não suporta módulos nativos Use as técnicas abaixo para trabalhar em torno de exigir exigências dinâmicas para excluir o módulo do pacote , E implantar ao longo do lado do executável em uma pasta nodemodule para que seu aplicativo pode encontrá-lo. Nota: No Windows, pode ser necessário que o aplicativo seja nomeado node. exe se o arquivo. node depender do nó. Doesnt suporte dinâmico exigir instruções Neste caso nexe não irá agrupar o arquivo Neste caso nexe irá agrupar ambos os arquivos. Soluções alternativas: 1) para dinâmico requer que você queira agregado adicione o seguinte em seu projeto isso irá enganar o bundler para incluí-los. 2) para arquivos dinâmicos sendo incluído que você não quer ser Nota: nem arquivo será empacotado. Usando essas duas técnicas, você pode alterar seu código de aplicativo para que os módulos não sejam bundles e gerar um arquivo includes. js como parte de seu processo de compilação para que os arquivos corretos sejam empacotados para sua configuração de compilação. Dirname Uma vez que o módulo é empacotado é parte do executável. Dirname é, portanto, o dir executável (process. execPath). Assim, se você colocar recursos em um caminho relativo do executável, seu aplicativo poderá acessá-los. Se você tivesse um arquivo de dados em /dev/myNodeApp/stateManager/handler/data/some. csv e um arquivo em /dev/myNodeApp/stateManager/handler/loader. js Você precisaria implantar some. csv em um subdiretor de dados / Ao lado do seu executável Há possíveis casos de uso para dirname onde o caminho executável não é a substituição correta e pode resultar em um erro silencioso (possivelmente mesmo em uma dependência que você não tem conhecimento). Nota: o nome do arquivo será indefinido childprocess. fork childprocess. spawn works não será modificado, mas childprocess. fork fará uma tentativa de iniciar uma nova instância do seu executável e executar o módulo empacotado. InstalaçãoParallel Kingdom Breaks 100,000 Usuários Parallel Kingdom. Pela empresa-membro PerBlue dos Empreendedores de Capital. Recentemente registrado seu 100.000 usuário. Congrats à equipe de PerBlue em seu sucesso continuado Do blog de PerBlue8217s: 8230Parallel Kingdom recentemente alcançou um marco do tempo longo. Agora temos mais de 100.000 contas de usuário PK. That8217s um monte de PK8217ers de todo o mundo. Alguns outros números divertidos: 1015 cidades foram fundadas em PK. Existem 1.240.861 bandeiras, que representam cerca de 425.000 km de território reivindicado em todo o mundo. Isso pode soar como um lote, mas é menos do que 1 da superfície da Terra. Que deixa 509.647.000 km de espaços não reclamados território 8211 ir reivindicar alguns Uma resposta para Parallel Kingdom Breaks 100.000 usuários Deixe uma resposta Cancelar resposta Inscreva-se para atualizações de eventos públicos: Startup Notícias Empresa Blogs ArchivesNode. js v6.7.0 Documentação Conteúdo File System File I / O é fornecida por invólucros simples em torno de funções padrão POSIX. Para usar este módulo é necessário (39fs39). Todos os métodos têm formas assíncronas e síncronas. O formulário assíncrono sempre leva um retorno de chamada de conclusão como seu último argumento. Os argumentos passados para o retorno de chamada de conclusão dependem do método, mas o primeiro argumento é sempre reservado para uma exceção. Se a operação foi concluída com êxito, o primeiro argumento será nulo ou indefinido. Ao usar o formulário síncrono todas as exceções são imediatamente lançadas. Você pode usar try / catch para lidar com exceções ou permitir que eles borbulham. Aqui está um exemplo da versão assíncrona: Aqui está a versão síncrona: Com os métodos assíncronos não há garantia de ordenação. Portanto, o seguinte é propenso a erro: Pode ser que fs. stat é executado antes de fs. rename. A maneira correta de fazer isso é encadear os retornos de chamada. Em processos ocupados, o programador é fortemente incentivado a usar as versões assíncronas dessas chamadas. As versões síncronas bloquearão todo o processo até concluírem - interromper todas as conexões. O caminho relativo para um nome de arquivo pode ser usado. Lembre-se, no entanto, que este caminho será relativo a process. cwd (). A maioria das funções fs permitem omitir o argumento de retorno de chamada. Se você fizer isso, um retorno de chamada padrão é usado que rethrows erros. Para obter um rastreamento para o site de chamada original, defina a variável de ambiente NODEDEBUG: Buffer API fs funções suporte passando e recebendo caminhos como seqüências de caracteres e Buffers. O último destina-se a tornar possível trabalhar com sistemas de arquivos que permitem nomes de arquivos não-UTF-8. Para a maioria dos usos típicos, trabalhar com caminhos como Buffers será desnecessário, como a seqüência de caracteres API converte para e de UTF-8 automaticamente. Observe que em determinados sistemas de arquivos (como NTFS e HFS) os nomes de arquivos sempre serão codificados como UTF-8. Em tais sistemas de arquivos, passar Buffers não-UTF-8 codificado para funções fs não funcionará como esperado. Classe: fs. FSWatcher Objetos retornados de fs. watch () são deste tipo. O callback ouvinte fornecido para fs. watch () recebe os eventos de alteração FSWatcher39s retornados. O próprio objeto emite esses eventos: Evento: 39change39 Emitido quando algo é alterado em um diretório ou arquivo assistido. Veja mais detalhes em fs. watch (). O argumento filename pode não ser fornecido dependendo do suporte do sistema operacional. Se o nome do arquivo for fornecido, ele será fornecido como um Buffer se fs. watch () for chamado com a opção de codificação de it39s definida como 39buffer39. Caso contrário, o nome do arquivo será uma string. Evento: 39error39 Emitido quando ocorre um erro. Watcher. close () Emitido quando o descritor de arquivo subjacente do WriteStream 39s foi fechado usando o método fs. close (). WriteStream. bytesWritten O número de bytes escritos até agora. Não inclui dados que ainda estão na fila para gravação. WriteStream. path O caminho para o arquivo que o fluxo está gravando conforme especificado no primeiro argumento para fs. createWriteStream (). Se o caminho for passado como uma string, writeStream. path será uma string. Se o caminho for passado como um Buffer. Então writeStream. path será um Buffer. Fs. access (path, mode, callback) Adicionado em: v0.11.15 Testa as permissões de um usuário para o arquivo ou diretório especificado pelo caminho. O argumento mode é um inteiro opcional que especifica as verificações de acessibilidade a serem executadas. As seguintes constantes definem os valores possíveis de modo. É possível criar uma máscara que consiste no OR bit a bit de dois ou mais valores. Fs. constants. FOK - o caminho é visível para o processo de chamada. Isso é útil para determinar se um arquivo existe, mas não diz nada sobre as permissões rwx. Padrão se nenhum modo for especificado. Fs. constants. ROK - o caminho pode ser lido pelo processo de chamada. Fs. constants. WOK - path pode ser escrito pelo processo de chamada. Fs. constants. XOK - path pode ser executado pelo processo de chamada. Isso não tem nenhum efeito no Windows (vai se comportar como fs. constants. FOK). O argumento final, callback. É uma função de chamada de retorno que é invocada com um argumento de erro possível. Se qualquer uma das verificações de acessibilidade falhar, o argumento de erro será preenchido. O exemplo a seguir verifica se o arquivo / etc / passwd pode ser lido e gravado pelo processo atual. Usando fs. access () para verificar a acessibilidade de um arquivo antes de chamar fs. open (). Fs. readFile () ou fs. writeFile () não é recomendado. Fazer isso introduz uma condição de corrida, já que outros processos podem alterar o estado do arquivo entre as duas chamadas. Em vez disso, o código de usuário deve abrir / ler / gravar o arquivo diretamente e manipular o erro gerado se o arquivo não estiver acessível. Write (NOT RECOMMENDED) read (NOT RECOMMENDED) O quotnot recommendedquot exemplos acima verificar a acessibilidade e, em seguida, usar o arquivo os exemplos quotrecommendedquot são melhores porque eles usam o arquivo diretamente e lidar com o erro, se houver. Em geral, verifique a acessibilidade de um arquivo somente se o arquivo não será usado diretamente, por exemplo quando sua acessibilidade é um sinal de outro processo. Fs. accessSync (path, mode) Adicionado em: v0.11.15 Versão síncrona do fs. access (). Isso lança se qualquer verificação de acessibilidade falhar, e não faz nada caso contrário. Fs. appendFile (arquivo, dados, opções, callback) Adiciona dados de maneira assíncrona a um arquivo, criando o arquivo se ele ainda não existir. Os dados podem ser uma string ou um buffer. Se options for uma string, então ela especifica a codificação. Exemplo: Qualquer descritor de arquivo especificado deve ter sido aberto para inclusão. Nota: Se um descritor de arquivo for especificado como o arquivo. Ele não será fechado automaticamente. Fs. appendFileSync (arquivo, dados, opções) A versão síncrona do fs. appendFile (). Retorna indefinido. Fs. chmod (caminho, modo, callback) Chmod assíncrono (2). Nenhum argumento que não seja uma possível exceção é dado ao retorno de chamada de conclusão. Fs. chmodSync (caminho, modo) Chmod síncrono (2). Retorna indefinido. Fs. chown (path, uid, gid, callback) Chunk assíncrono (2). Nenhum argumento que não seja uma possível exceção é dado ao retorno de chamada de conclusão. Fs. chownSync (caminho, uid, gid) Chunk síncrono (2). Retorna indefinido. Fs. close (fd, callback) Assíncrono close (2). Nenhum argumento que não seja uma possível exceção é dado ao retorno de chamada de conclusão. Fs. closeSync (fd) Sincronizado close (2). Retorna indefinido. Fs. constents Retorna um objeto que contém constantes comumente usadas para operações do sistema de arquivos. As constantes específicas atualmente definidas são descritas em Constantes FS. Fs. createReadStream (caminho, opções) Lembre-se de que, ao contrário do valor padrão definido para highWaterMark em um fluxo legível (16 kb), o fluxo retornado por este método tem um valor padrão de 64 kb para o mesmo parâmetro. É um objeto ou seqüência de caracteres com os seguintes padrões: opções podem incluir valores de início e fim para ler um intervalo de bytes do arquivo em vez de todo o arquivo. Tanto o início como o fim são inclusivos e começam em 0. A codificação pode ser qualquer uma daquelas aceitas pelo Buffer. Se fd for especificado, o ReadStream ignorará o argumento path e usará o descritor de arquivo especificado. Isso significa que nenhum evento 39open39 será emitido. Observe que fd deve estar bloqueando não-bloqueio fd s deve ser passado para net. Socket. Se autoClose for false, então o descriptor de arquivo não será fechado, mesmo se houver um erro. É sua responsabilidade fechá-lo e certifique-se de que não há vazamento de descritor de arquivo. Se autoClose for definido como true (comportamento padrão), em erro ou no final o descritor de arquivo será fechado automaticamente. Mode define o modo de arquivo (permissão e sticky bits), mas somente se o arquivo foi criado. Um exemplo para ler os últimos 10 bytes de um arquivo com 100 bytes de comprimento: Se options é uma string, então especifica a codificação. Opções fs. createWriteStream (caminho, opções) é um objeto ou seqüência de caracteres com as seguintes opções padrão: as opções também podem incluir uma opção de início para permitir a gravação de dados em alguma posição após o início do arquivo. Modificar um arquivo em vez de substituí-lo pode exigir um modo sinalizadores de r em vez do modo padrão w. O defaultEncoding pode ser qualquer um daqueles aceitos pelo Buffer. Se autoClose estiver definido como true (comportamento padrão) no erro ou no final, o descritor de arquivo será fechado automaticamente. Se autoClose for false, então o descriptor de arquivo não será fechado, mesmo se houver um erro. É sua responsabilidade fechá-lo e certifique-se de que não há vazamento de descritor de arquivo. Como o ReadStream. Se fd for especificado, WriteStream irá ignorar o argumento de caminho e usará o descritor de arquivo especificado. Isso significa que nenhum evento 39open39 será emitido. Observe que fd deve estar bloqueando não-bloqueio fd s deve ser passado para net. Socket. Se options for uma string, então ela especifica a codificação. Fs. exists (path, callback) Adicionado em: v0.0.2 Deprecated since: v1.0.0 Teste se existe ou não o caminho dado, verificando com o sistema de arquivos. Em seguida, chame o argumento de retorno de chamada com true ou false. Exemplo: Usando fs. exists () para verificar a existência de um arquivo antes de chamar fs. open (). Fs. readFile () ou fs. writeFile () não é recomendado. Fazer isso introduz uma condição de corrida, já que outros processos podem alterar o estado do arquivo entre as duas chamadas. Em vez disso, o código do usuário deve abrir / ler / gravar o arquivo diretamente e manipular o erro levantado se o arquivo não existir. Write (NOT RECOMMENDED) read (NOT RECOMMENDED) O quotnot recommendedquot exemplos acima verificar existência e usar o arquivo os exemplos quotrecommendedquot são melhores porque eles usam o arquivo diretamente e manipular o erro, se houver. Em geral, verifique a existência de um arquivo somente se o arquivo não será usado diretamente, por exemplo quando sua existência é um sinal de outro processo. Fs. existsSync (caminho) Adicionado em: v0.1.21 Deprecated desde: v1.0.0 Versão síncrona de fs. exists (). Retorna true se o arquivo existir, false caso contrário. Fs. fchmod (fd, mode, callback) Assíncrono fchmod (2). Nenhum argumento que não seja uma possível exceção é dado ao retorno de chamada de conclusão. Fs. fchmodSync (fd, modo) Synchro fchmod (2). Retorna indefinido. Fs. fchown (fd, uid, gid, callback) Fitch assíncrono (2). Nenhum argumento que não seja uma possível exceção é dado ao retorno de chamada de conclusão. Fs. fchownSync (fd, uid, gid) Ficha síncrona (2). Retorna indefinido. Fs. fdatasync (fd, callback) Assíncrono fdatasync (2). Nenhum argumento que não seja uma possível exceção é dado ao retorno de chamada de conclusão. Fs. fdatasyncSync (fd) Synchronous fdatasync (2). Retorna indefinido. Fs. fstat (fd, callback) Fstat assíncrono (2). O callback obtém dois argumentos (err, stats) onde stats é um objeto fs. Stats. Fstat () é idêntico a stat (). Exceto que o arquivo a ser stat-ed é especificado pelo descritor de arquivo fd. Fs. fstatSync (fd) Fstat síncrono (2). Retorna uma instância de fs. Stats. Fs. fsync (fd, callback) Assíncrono fsync (2). Nenhum argumento que não seja uma possível exceção é dado ao retorno de chamada de conclusão. Fs. fsyncSync (fd) Synchronous fsync (2). Retorna indefinido. Fs. ftruncate (fd, len, callback) Assíncrono ftruncate (2). Nenhum argumento que não seja uma possível exceção é dado ao retorno de chamada de conclusão. Se o arquivo referido pelo descritor de arquivo era maior do que bytes de len, somente os primeiros bytes de len serão mantidos no arquivo. Por exemplo, o seguinte programa retém apenas os primeiros quatro bytes do arquivo Se o arquivo anteriormente era menor do que len bytes, ele é estendido e a parte estendida é preenchida com bytes nulos (39039). Por exemplo, Os últimos três bytes são bytes nulos (39039), para compensar o sobre-truncamento. Fs. ftruncateSync (fd, len) fd ltIntegergt ltIntegergt default 0 Sincronizado ftruncate (2). Retorna indefinido. Fs. futimes (fd, atime, mtime, callback) Altere os carimbos de data / hora do arquivo de um arquivo referenciado pelo descritor de arquivo fornecido. Fs. futimesSync (fd, atime, mtime) fd ltIntegergt atime ltIntegergt mtime ltIntegergt Versão síncrona de fs. futimes (). Retorna indefinido. Fs. lchmod (caminho, modo, callback) Desatualizado desde: v0.4.7 Lchmod assíncrono (2). Nenhum argumento que não seja uma possível exceção é dado ao retorno de chamada de conclusão. Apenas disponível no Mac OS X. fs. lchmodSync (caminho, modo) Desativado desde: v0.4.7 Synchrone lchmod (2). Retorna indefinido. Fs. lchown (path, uid, gid, callback) Desatualizado desde: v0.4.7 Linguagem assíncrona (2). Nenhum argumento que não seja uma possível exceção é dado ao retorno de chamada de conclusão. Fs. lchownSync (path, uid, gid) Desatualizado desde: v0.4.7 LCHST síncrono (2). Retorna indefinido. Fs. link (srcpath, dstpath, callback) Ligação assíncrona (2). Nenhum argumento que não seja uma possível exceção é dado ao retorno de chamada de conclusão. Fs. linkSync (srcpath, dstpath) Ligação síncrona (2). Retorna indefinido. Fs. lstat (caminho, retorno de chamada) lstat assíncrono (2). O callback obtém dois argumentos (err, stats) onde stats é um objeto fs. Stats. Lstat () é idêntico a stat (). Exceto que se path for um link simbólico, então o link em si será stat-ed, não o arquivo ao qual ele se refere. Fs. lstatSync (caminho) Lstat síncrono (2). Retorna uma instância de fs. Stats. Fs. mkdir (caminho, modo, callback) Mkdir assíncrono (2). Nenhum argumento que não seja uma possível exceção é dado ao retorno de chamada de conclusão. O modo padrão é 0o777. Fs. mkdirSync (caminho, modo) Synchronous mkdir (2). Retorna indefinido. Fs. mkdtemp (prefixo, opções, callback) Cria um diretório temporário exclusivo. Gera seis caracteres aleatórios a serem anexados por trás de um prefixo necessário para criar um diretório temporário exclusivo. O caminho da pasta criada é passado como uma string para o segundo parâmetro do callback39s. O argumento options opcional pode ser uma string especificando uma codificação, ou um objeto com uma propriedade de codificação especificando a codificação de caracteres a ser usada. Nota . O método fs. mkdtemp () anexará os seis caracteres selecionados aleatoriamente diretamente à seqüência de prefixo. Por exemplo, dado um diretório / tmp. Se a intenção é criar um diretório temporário dentro de / tmp. O prefixo deve terminar com um separador de caminho específico de plataforma à direita (require (39path39).sep). Fs. mkdtempSync (prefix, options) A versão síncrona do fs. mkdtemp (). Retorna o caminho da pasta criada. O argumento options opcional pode ser uma string especificando uma codificação, ou um objeto com uma propriedade de codificação especificando a codificação de caracteres a ser usada. Fs. open (caminho, flags, mode, callback) Arquivo assíncrono aberto. Ver aberto (2). As bandeiras podem ser: 39r39 - Abra o arquivo para leitura. Ocorre uma exceção se o arquivo não existir. 39r39 - Abrir arquivo para leitura e escrita. Ocorre uma exceção se o arquivo não existir. 39rs39 - Abrir arquivo para leitura e escrita em modo síncrono. Instrui o sistema operacional a ignorar o cache do sistema de arquivos local. Isso é útil principalmente para abrir arquivos em montagens NFS, pois permite que você ignore o cache local potencialmente antigo. Tem um impacto muito real no desempenho de E / S para que não use esta bandeira a menos que você precise dela. Observe que isso não transforma fs. open () em uma chamada de bloqueio síncrono. Se isso é o que você quer, então você deve usar fs. openSync () 39w39 - Abra o arquivo para escrever. O arquivo é criado (se não existir) ou truncado (se existir). 39wx39 - Como 39w39 mas falha se o caminho existir. 39w39 - Abrir arquivo para leitura e escrita. O arquivo é criado (se não existir) ou truncado (se existir). 39wx39 - Como 39w39 mas falha se o caminho existir. 39a39 - Abrir arquivo para anexar. O arquivo é criado se ele não existir. 39ax39 - Como 39a39 mas falha se o caminho existir. 39a39 - Abrir arquivo para leitura e anexação. O arquivo é criado se ele não existir. 39ax39 - Como 39a39 mas falha se o caminho existir. Mode define o modo de arquivo (permissão e sticky bits), mas somente se o arquivo foi criado. O padrão é 0666. legível e gravável. O callback obtém dois argumentos (err, fd). O sinalizador exclusivo 39x39 (sinalizador OEXCL em aberto (2)) garante que o caminho é recém-criado. Nos sistemas POSIX, o caminho é considerado existir mesmo se for um link simbólico para um arquivo inexistente. A bandeira exclusiva pode ou não funcionar com sistemas de arquivos de rede. Flags também podem ser um número conforme documentado por open (2) as constantes usadas normalmente estão disponíveis em fs. constants. No Windows, os sinalizadores são traduzidos para os seus equivalentes quando aplicável, p. OWRONLY para FILEGENERICWRITE. Ou OEXCLOCREAT para CREATENEW. Como aceito por CreateFileW. No Linux, as escrituras posicional não funcionam quando o arquivo é aberto no modo de anexação. O kernel ignora o argumento de posição e sempre anexa os dados ao final do arquivo. Nota: O comportamento de fs. open () é específico da plataforma para alguns sinalizadores. Como tal, abrir um diretório no OS X e no Linux com o sinalizador 39a39 - veja o exemplo abaixo - retornará um erro. Em contraste, no Windows e FreeBSD, um descritor de arquivo será retornado. Fs. openSync (path, flags, mode) Versão síncrona do fs. open (). Retorna um inteiro representando o descritor de arquivo. Fs. read (fd, buffer, offset, length, position, callback) Ler dados do arquivo especificado por fd. Buffer é o buffer que os dados serão gravados para. Offset é o deslocamento no buffer para começar a escrever em. Length é um número inteiro que especifica o número de bytes a ler. Position é um número inteiro que especifica onde começar a ler no arquivo. Se a posição for nula. Os dados serão lidos da posição atual do arquivo. O retorno de chamada é dado os três argumentos, (err, bytesRead, buffer). Fs. readdir (caminho, opções, callback) Readdir assíncrono (3). Lê o conteúdo de um diretório. O callback obtém dois argumentos (err, files) onde files é uma matriz dos nomes dos arquivos no diretório excluindo 39.39 e 39..39. O argumento options opcional pode ser uma string especificando uma codificação, ou um objeto com uma propriedade de codificação especificando a codificação de caracteres a ser usada para os nomes de arquivos passados para o callback. Se a codificação estiver definida para 39buffer39. Os nomes de arquivos retornados serão passados como objetos Buffer. Fs. readdirSync (caminho, opções) Readdir síncrono (3). Retorna uma matriz de nomes de arquivo excluindo 39.39 e 39..39. O argumento options opcional pode ser uma string especificando uma codificação, ou um objeto com uma propriedade de codificação especificando a codificação de caracteres a ser usada para os nomes de arquivos passados para o callback. Se a codificação estiver definida como 39buffer39. Os nomes de arquivos retornados serão passados como objetos Buffer. Fs. readFile (arquivo, opções, callback) Lê assincronamente todo o conteúdo de um arquivo. Exemplo: O retorno de chamada é passado dois argumentos (err, dados). Onde dados são o conteúdo do arquivo. Se nenhuma codificação for especificada, o buffer bruto será retornado. Se options for uma string, então ela especifica a codificação. Exemplo: Qualquer descritor de arquivo especificado tem que suportar a leitura. Nota: Se um descritor de arquivo for especificado como o arquivo. Ele não será fechado automaticamente. Fs. readFileSync (file, options) Versão síncrona de fs. readFile. Retorna o conteúdo do arquivo. Se a opção de codificação for especificada, esta função retornará uma string. Caso contrário, retorna um buffer. Fs. readlink (caminho, opções, callback) Readlink assíncrono (2). O retorno de chamada recebe dois argumentos (err, linkString). O argumento options opcional pode ser uma string especificando uma codificação ou um objeto com uma propriedade de codificação especificando a codificação de caracteres a ser usada para o caminho de link passado para o callback. Se a codificação estiver definida como 39buffer39. O caminho de link retornado será passado como um objeto Buffer. Fs. readlinkSync (caminho, opções) Synchronous readlink (2). Retorna o valor da seqüência do link39s simbólico. O argumento options opcional pode ser uma string especificando uma codificação ou um objeto com uma propriedade de codificação especificando a codificação de caracteres a ser usada para o caminho de link passado para o callback. Se a codificação estiver definida como 39buffer39. O caminho de link retornado será passado como um objeto Buffer. Fs. readSync (fd, buffer, offset, length, position) Versão síncrona de fs. read (). Retorna o número de bytesRead. Fs. realpath (caminho, opções, callback) Realpath assíncrono (3). O callback obtém dois argumentos (err, resolvedPath). Pode usar process. cwd para resolver caminhos relativos. Apenas caminhos que podem ser convertidos em cadeias UTF8 são suportados. O argumento options opcional pode ser uma string especificando uma codificação ou um objeto com uma propriedade de codificação especificando a codificação de caracteres a ser usada para o caminho passado para o callback. Se a codificação estiver definida como 39buffer39. O caminho retornado será passado como um objeto Buffer. Fs. realpathSync (caminho, opções) Synchronous realpath (3). Retorna o caminho resolvido. Somente caminhos que podem ser convertidos em seqüências de caracteres UTF8 são suportados. O argumento options opcional pode ser uma string especificando uma codificação ou um objeto com uma propriedade de codificação especificando a codificação de caracteres a ser usada para o valor retornado. Se a codificação estiver definida para 39buffer39. O caminho retornado será passado como um objeto Buffer. Fs. rename (oldPath, newPath, callback) Assíncrono renomear (2). Nenhum argumento que não seja uma possível exceção é dado ao retorno de chamada de conclusão. Fs. renameSync (oldPath, newPath) Renomeação síncrona (2). Retorna indefinido. Fs. rmdir (caminho, callback) Assíncrono rmdir (2). Nenhum argumento que não seja uma possível exceção é dado ao retorno de chamada de conclusão. Fs. rmdirSync (caminho) Synchronous rmdir (2). Retorna indefinido. Fs. stat (caminho, callback) Assíncrono stat (2). O callback obtém dois argumentos (err, stats) onde stats é um objeto fs. Stats. Consulte a seção fs. Stats para obter mais informações. Fs. statSync (caminho) Síncrono stat (2). Retorna uma instância de fs. Stats. Fs. symlink (destino, caminho, tipo, retorno de chamada) Assíncrono symlink (2). Nenhum argumento que não seja uma possível exceção é dado ao retorno de chamada de conclusão. O argumento de tipo pode ser definido como 39dir39. 39file39. Ou 39junction39 (o padrão é 39file39) e só está disponível no Windows (ignorado em outras plataformas). Observe que os pontos de junção do Windows exigem que o caminho de destino seja absoluto. Ao usar 39junction39. O argumento de destino será automaticamente normalizado para o caminho absoluto. Aqui está um exemplo abaixo: Ele cria um link simbólico chamado quotnew-portquot que aponta para quotfooquot. Fs. symlinkSync (destino, caminho, tipo) Sincronização do link simbólico (2). Retorna indefinido. Fs. truncate (path, len, callback) Assíncrono truncate (2). Nenhum argumento que não seja uma possível exceção é dado ao retorno de chamada de conclusão. Um descritor de arquivo também pode ser passado como o primeiro argumento. Neste caso, fs. ftruncate () é chamado. Fs. truncateSync (caminho, len) Synchronous truncate (2). Retorna indefinido. Um descritor de arquivo também pode ser passado como o primeiro argumento. Nesse caso, fs. ftruncateSync () é chamado. Fs. unlink (caminho, retorno de chamada) Assinchronous unlink (2). Nenhum argumento que não seja uma possível exceção é dado ao retorno de chamada de conclusão. Fs. unlinkSync (path) Sincronização de unlink (2). Retorna undefined. Fs. unwatchFile (nome do arquivo, ouvinte) Pare de observar as alterações no nome do arquivo. Se o ouvinte for especificado, somente esse ouvinte em particular será removido. Caso contrário, todos os ouvintes são removidos e você efetivamente parou de assistir nome do arquivo. Chamar fs. unwatchFile () com um nome de arquivo que não está sendo observado é um não-op, não um erro. Nota: fs. watch () é mais eficiente do que fs. watchFile () e fs. unwatchFile (). Fs. watch () deve ser usado em vez de fs. watchFile () e fs. unwatchFile () quando possível. Fs. utimes (path, atime, mtime, callback) Modifica os timestamps do arquivo referenciado pelo caminho fornecido. Nota: os argumentos atime e mtime das seguintes funções relacionadas seguem as regras abaixo: Se o valor é uma string numerável como 3912345678939. o valor seria convertido para o número correspondente. Se o valor for NaN ou Infinity. O valor seria convertido para Date. now (). Fs. utimesSync (caminho, atime, mtime) Versão síncrona de fs. utimes (). Retorna indefinido. Fs. watch (nome do arquivo, opções, listener) nome do arquivo ltStringgt ltBuffergt opções ltStringgt ltObjectgt persistent ltBooleangt Indica se o processo deve continuar a ser executado enquanto os arquivos estiverem sendo assistidos. Default true recursive ltBooleangt Indica se todos os subdiretórios devem ser vistos, ou apenas o diretório atual. Aplica-se quando um diretório é especificado e somente em plataformas suportadas (consulte Advertências). Default false encoding ltStringgt Especifica a codificação de caracteres a ser usada para o nome do arquivo passado para o ouvinte. Default 39utf839 listener ltFunctiongt Observe as alterações feitas no nome do arquivo. Onde filename é um arquivo ou um diretório. O objeto retornado é um fs. FSWatcher. O segundo argumento é opcional. Se opções for fornecido como uma seqüência de caracteres, ele especifica a codificação. Caso contrário, as opções devem ser passadas como um objeto. O callback do listener recebe dois argumentos (eventType, filename). EventType é 39rename39 ou 39change39. E filename é o nome do arquivo que acionou o evento. Observe que o callback do ouvinte está anexado ao evento 39change39 disparado por fs. FSWatcher. Mas não são a mesma coisa. Advertências A API fs. watch não é 100 consistente entre plataformas e não está disponível em algumas situações. A opção recursiva só é suportada no OS X e Windows. Disponibilidade Este recurso depende do sistema operacional subjacente, fornecendo uma forma de ser notificado das alterações no sistema de arquivos. Em sistemas Linux, isso usa inotify Em sistemas BSD, isso usa kqueue No OS X, isso usa kqueue para arquivos e FSEvents para diretórios. Em sistemas SunOS (incluindo Solaris e SmartOS), isso usa portas de eventos. Em sistemas Windows, esse recurso depende do ReadDirectoryChangesW. Nos sistemas AIX, este recurso depende do AHAFS. Que deve ser habilitado. Se a funcionalidade subjacente não estiver disponível por algum motivo, fs. watch não será capaz de funcionar. Por exemplo, assistir a arquivos ou diretórios pode não ser confiável e, em alguns casos, impossível, em sistemas de arquivos em rede (NFS, SMB, etc.) ou sistemas de arquivos host ao usar software de virtualização como Vagrant, Docker etc..watchFile. Que usa sondagem estatística, mas é mais lento e menos confiável. Inodes Nos sistemas Linux e OS X, fs. watch () resolve o caminho para um inode e observa o inode. Se o caminho assistido é excluído e recriado, é atribuído um novo inode. O relógio emitirá um evento para a exclusão, mas continuará assistindo o inode original. Os eventos para o novo inode não serão emitidos. Esse é o comportamento esperado. Filename Argument Providing filename argumento no callback só é suportado no Linux e Windows. Mesmo em plataformas suportadas, o nome de arquivo nem sempre é garantido para ser fornecido. Portanto, não considere que o argumento do nome de arquivo é sempre fornecido no retorno de chamada, e tem alguma lógica de retorno se for nulo. Fs. watchFile (nome do arquivo, opções, ouvinte) Observe as alterações no nome do arquivo. O chamador de chamada de retorno será chamado cada vez que o arquivo é acessado. O argumento opções pode ser omitido. Se fornecido, ele deve ser um objeto. O objeto de opções pode conter um booleano chamado persistente que indica se o processo deve continuar a ser executado, desde que os arquivos estejam sendo assistidos. O objeto de opções pode especificar uma propriedade de intervalo indicando com que freqüência o alvo deve ser consultado em milissegundos. O padrão é. O ouvinte obtém dois argumentos o objeto stat atual e o objeto stat anterior: Esses objetos stat são instâncias de fs. Stat. Se você quiser ser notificado quando o arquivo foi modificado, não apenas acessado, você precisa comparar curr. mtime e prev. mtime. Nota: quando uma operação fs. watchFile resulta em um erro ENOENT, invoca o ouvinte uma vez, com todos os campos zerados (ou, para datas, a Época Unix). No Windows, blksize e blocos campos serão indefinidos. Em vez de zero. Se o arquivo for criado posteriormente, o ouvinte será chamado novamente, com os objetos estatísticos mais recentes. Esta é uma alteração na funcionalidade desde v0.10. Nota: fs. watch () é mais eficiente do que fs. watchFile e fs. unwatchFile. Fs. watch deve ser usado em vez de fs. watchFile e fs. unwatchFile quando possível. fs. write(fd, buffer, offset, length, position, callback) Write buffer to the file specified by fd . offset and length determine the part of the buffer to be written. position refers to the offset from the beginning of the file where this data should be written. If typeof position 39number39. the data will be written at the current position. See pwrite(2) . The callback will be given three arguments (err, written, buffer) where written specifies how many bytes were written from buffer . Note that it is unsafe to use fs. write multiple times on the same file without waiting for the callback. For this scenario, fs. createWriteStream is strongly recommended. On Linux, positional writes don39t work when the file is opened in append mode. The kernel ignores the position argument and always appends the data to the end of the file. fs. write(fd, data, position, encoding, callback) Write data to the file specified by fd. If data is not a Buffer instance then the value will be coerced to a string. position refers to the offset from the beginning of the file where this data should be written. If typeof position 39number39 the data will be written at the current position. See pwrite(2) . encoding is the expected string encoding. The callback will receive the arguments (err, written, string) where written specifies how many bytes the passed string required to be written. Note that bytes written is not the same as string characters. See Buffer. byteLength . Unlike when writing buffer. the entire string must be written. No substring may be specified. This is because the byte offset of the resulting data may not be the same as the string offset. Note that it is unsafe to use fs. write multiple times on the same file without waiting for the callback. For this scenario, fs. createWriteStream is strongly recommended. On Linux, positional writes don39t work when the file is opened in append mode. The kernel ignores the position argument and always appends the data to the end of the file. fs. writeFile(file, data, options, callback) Asynchronously writes data to a file, replacing the file if it already exists. data can be a string or a buffer. The encoding option is ignored if data is a buffer. It defaults to 39utf839 . If options is a string, then it specifies the encoding. Example: Any specified file descriptor has to support writing. Note that it is unsafe to use fs. writeFile multiple times on the same file without waiting for the callback. For this scenario, fs. createWriteStream is strongly recommended. Note: If a file descriptor is specified as the file. it will not be closed automatically. fs. writeFileSync(file, data, options) The synchronous version of fs. writeFile(). Returns undefined . fs. writeSync(fd, buffer, offset, length, position) fs. writeSync(fd, data, position, encoding) Synchronous versions of fs. write(). Returns the number of bytes written. FS Constants The following constants are exported by fs. constants. Note: Not every constant will be available on every operating system. File Access Constants The following constants are meant for use with fs. access().Accessing the File System in Node. js For years, JavaScript has had very limited access to the file system. Of course, for most of its life, JavaScript lived in the browser. For a web scripting language, accessing the file system was considered a major security risk. Front end developers have been forced to make due with cookies, web storage. ActiveX. Flash, and other technologies. HTML5 brought about the file system API. but it remains largely unsupported outside of Chrome. With the advent of Node. js, JavaScript began to gain footing as a legitimate server-side language. On the server, file system accesses are a regular occurrence, making the thought of an API much less concerning. The File System Module By default, Node. js installations come with the file system module, fs. For the most part, fs simply provides a wrapper for the standard file operations. The following example uses the file system module to read the contents of a file into memory. First, the file system module is imported on line 1. On line 3, the exists() function determines if the file 8220foo. txt8221 exists. The exists() callback function takes a Boolean argument which specifies if the file exists or not. From there, the stat() function is used to determine the length of the file in bytes. This information is important so we know how much data to read. Next, we open the file using open(). The r argument denotes that the file is being opened for reading. The open() callback function provides a file descriptor. fd for accessing the newly opened file. Inside the callback function, we define a buffer to hold the file8217s contents. Notice that the buffer is initialized to the file8217s size, which is stored in stats. size. Next, the file is read into the buffer using the read() function. The buffer now contains the raw data read from the file. In order to display the data, we must first convert it to a UTF-8 encoded string. Finally, the file contents are printed to the console, and the file is closed. Synchronous Functions While looking over the documentation, you may notice that many of the functions end with Sync. These represent synchronous functions 8211 a bit of a rarity in the callback driven world of Node. js. The synchronous functions are provided for convenience. For example, a simple batch script written in Node. js probably doesn8217t need to worry about maximizing performance. The synchronous functions are also useful for loading certain files during program initialization. However, in an active server application, the synchronous functions have the potential to seriously hamper performance by stalling Node8217s single thread of execution. The following examples show how a file can be read into memory both synchronously and asynchronously. Our previous example of reading a file is a bit convoluted, to say the least. This time, our example uses the readFile() function to read an entire file in a single function call. The first two arguments to readFile() are the filename and its encoding. Following Node. js convention, the final argument is the callback function. The callback function8217s arguments provide error information and the file contents. The following example performs the same task synchronously using readFileSync(). The synchronous code is slightly more readable, but does not offer the same scalability as its asynchronous counterpart. Watching Files The file system module allows programs to watch for modifications to specific files. This is very useful in programs such as nodemon. which automatically restarts a program when its source code is modified. The following example watches a file named 8220foo. txt8221. When the file is modified, the type of event is printed to the console. The watch() function takes three arguments. The first argument is the name of the file to watch. The second argument is optional, and provides configuration settings. If present, the second argument should be an object containing a Boolean value named persistent. If true. persistent prevents the program from terminating. If the second argument is omitted, it defaults to true. The final argument is a callback which is triggered when the target file is modified. The callback passes in the type of event (change, rename, etc.) and the name of the file. It is worth noting that watch() is dependent on the underlying OS, and might not work on every system. If watch() is unavailable, the slower watchFile() can be used as a backup. Conclusion This article has introduced the Node. js file system module at a very high level. The module contains over 50 different functions, which is obviously too much for one article. For example, this article has only touched on reading files, and has completely neglected writing to files. I encourage you to browse the module documentation to get a more in depth understanding. And remember, the synchronous functions should be used with extreme caution Latest Courses Latest Books Recommended Sponsors
No comments:
Post a Comment