fs模块包含所有文件查询和处理的相关函数,用这些函数,可以查询文件信息,读写和关闭文件。
使用fs.stath函数来查询文件或目录的元信息,异步——fs.stat('/etc/passwd',function(err, stats){})。
fs.stat()调用会将一个stats类的实例作为参数传递给它的回调函数,可以像下面这样使用stats实例:
(1)stats.isFile() ―― 如果是个标准文件,而不是目录,socket,符号链接或者设备,则返回true,否则false
(2)stats.isDiretory() ―― 如果是目录则返回tue,否则false
(3)stats.isBlockDevice() ―― 如果是块设备则返回true,在大多数UNIX系统中块设备通常都在/dev目录下
(4)stats.isChracterDevice() ―― 如果是字符设备返回true
(5)stats.isSymbolickLink() ―― 如果是文件链接返回true
(6)stats.isFifo() ―― 如果是个FIFO(UNIX命名管道的一个特殊类型返回true
(7)stats.isSocket() ―― 如果是个UNIX socket返回true
用fs.open函数打开文件,fs.open('/path/to/file','r',function(err, fd){} —— 第一个参数是文件路径,第二个参数是一些用来指示以什么模式打开文件的标记。标记有:(1)r ―― 以只读方式打开文件,数据流的初始位置在文件开始(2)r+ ―― 以可读写方式打开文件,数据流的初始位置在文件开始(3)w ――如果文件存在,则将文件长度清0,即该文件内容会丢失。如果不存在,则尝试创建它。数据流的初始位置在文件开始(4)w+ ―― 以可读写方式打开文件,如果文件不存在,则尝试创建它,如果文件存在,则将文件长度清0,即该文件内容会丢失。数据流的初始位置在文件开始(5)a ―― 以只写方式打开文件,如果文件不存在,则尝试创建它,数据流的初始位置在文件末尾,随后的每次写操作都会将数据追加到文件后面。(6)a+ ――以可读写方式打开文件,如果文件不存在,则尝试创建它,数据流的初始位置在文件末尾,随后的每次写操作都会将数据追加到文件后面。
fs.read函数来读取文件,但先创建一个缓冲区(buffer)来放置这些数据,fs.read(fd,readBuffer,bufferOffset,bufferLength,filePosition,function read(err, readBytes) {})——fd为打开文件的文件描述符,第二个参数是接收的缓冲区,第三个参数是接收缓冲区的偏移,第四个参数是接收的长度,第五个参数是读文件的起始位置。最后一个参数是回调函数,回调函数中的第二个参数(readBytes)会指明被读到缓冲区里数据的大小,如果值是0,则表示到达了文件末尾。注意:一旦把缓冲区对象传递给fs.open(),缓冲对象的控制权就转移给给了read命令,只有当回调函数被调用,缓冲区对象的控制权才会回到你手里。因此在这之前,不要读写或者让其它函数调用使用这个缓冲区对象;否则,你可能会读到不完整的数据,更糟的情况是,你可能会并发地往这个缓冲区对象里写数据。
fs.write()传递一个包含数据的缓冲对象,向一个已打开的文件里写数据。 fs.write( fd,writeBuffer,bufferPosition, bufferLength,filePosition, function wrote(err, written) {}),参数同读文件。
当Node进程结束时,操作系统会确保关闭所有文件。但在实际的应用程序中,一旦打开一个文件你要确保最终关闭它。使用fs.close(fd, function() {})来关闭文件。