Stability: 3 - Stable
文件系统模块是一个简单包装的标准
POSIX 文件 I/O 操作方法集。您可以通过调用require(‘fs‘)来获取该模块。文件系统模块中的所有方法均有异步和同步版本。
文件系统模块中的异步方法需要一个完成时的回调函数作为最后一个传入形参。
回调函数的构成由您调用的异步方法所决定,通常情况下回调函数的第一个形参为返回的错误信息。 如果异步操作执行正确并返回,该错误形参则为 null
或者undefined。
如果您使用的是同步版本的操作方法,则一旦出现错误,会以通常的抛出错误的形式返回错误。
你可以用try/catch等语句来拦截错误并使程序继续进行。
这里是一个异步版本的示例:
var fs = require(‘fs‘);
fs.unlink(‘/tmp/hello‘, function (err) {
if (err) throw err;
console.log(‘successfully deleted /tmp/hello‘);
});
这是同步版本的示例:
var fs = require(‘fs‘);
fs.unlinkSync(‘/tmp/hello‘)
console.log(‘successfully deleted /tmp/hello‘);
当使用异步方法时不能保证执行顺序,因此下面这个示例很容易出错:
fs.rename(‘/tmp/hello‘, ‘/tmp/world‘, function (err) {
if (err) throw err;
console.log(‘renamed complete‘);
});
fs.stat(‘/tmp/world‘, function (err, stats) {
if (err) throw err;
console.log(‘stats: ‘ + JSON.stringify(stats));
});
fs.stat有可能在fs.rename
前执行.要等到正确的执行顺序应该用下面的方法:
fs.rename(‘/tmp/hello‘, ‘/tmp/world‘, function (err) {
if (err) throw err;
fs.stat(‘/tmp/world‘, function (err, stats) {
if (err) throw err;
console.log(‘stats: ‘ + JSON.stringify(stats));
});
});
在忙碌的任务进程中,强烈推荐使用这些函数的异步调用.同步版本会阻塞进程,直到完成处理,也就是说会暂停所有的连接。可以使用文件名的相对路径,
但是记住这个路径是相对于process.cwd()的。
大部分的文件系统(fs)函数可以忽略回调函数(callback)这个参数.如果忽略它,将会由一个默认回调函数(callback)来重新抛出(rethrow)错误.要获得原调用点的堆栈跟踪(trace)信息,需要在环境变量里设置NODE_DEBUG.
$ cat script.js
function bad() {
require(‘fs‘).readFile(‘/‘);
}
bad();
$ env NODE_DEBUG=fs node script.js
fs.js:66
throw err;
^
Error: EISDIR, read
at rethrow (fs.js:61:21)
at maybeCallback (fs.js:79:42)
at Object.fs.readFile (fs.js:153:18)
at bad (/path/to/script.js:2:17)
at Object.<anonymous> (/path/to/script.js:5:1)
<etc.>
仅在
Mac OS X 系统下可用。
stats
是一个
fs.Stats对象。
详情请参考 fs.Stats.
stats
是一个fs.Stats对象。lstat()与stat()相同,区别在于:
若path
是一个符号链接时(symbolic
link),读取的是该符号链接本身,而不是它所 链接到的文件。
‘dir‘
, ‘file‘
或者junction‘
(默认是‘file‘),此参数仅用于
Windows 系统(其他系统平台会被忽略)。 注意: Windows 系统要求目标路径必须是一个绝对路径,当使用 ‘junction‘时,目标路径参数会自动转换为绝对路径。
同步版的 readlink(2).返回符号链接(symbolic link)的字符串值。
(err,
resolvedPath)
。可以通过 process.cwd
转化为相对路径。 cache
是一个文字映射路径,可用于强制一个特定的路径以解决或避免额外的 fs.stat
回调以得知真实路径。示例:
var cache = {‘/etc‘:‘/private/etc‘};
fs.realpath(‘/etc/passwd‘, cache, function (err, resolvedPath) {
if (err) throw err;
console.log(resolvedPath);
});
同步版的
unlink(2)。
mode
默认为0777。
‘.‘
和‘..‘
‘.‘
和‘..‘
目录。flags
可以是:‘r‘
- 以【只读】的方式打开文件. 当文件不存在时产生异常。‘r+‘
- 以【读写】的方式打开文件. 当文件不存在时产生异常。‘rs‘
- 同步模式下,以【只读】的方式打开文件. 指令绕过操作系统的本地文件系统缓存。fs.open()
变成了一个同步阻塞的请求.
如果你想要一个同步阻塞的请求你应该使用fs.openSync()‘rs+‘
- 同步模式下, 以【读写】的方式打开文件. 请谨慎使用该方式, 详细请查看 ‘rs‘
的注释。‘w‘
- 以【只写】的形式打开文件. 文件会被创建 (如果文件不存在) 或者覆盖 (如果存在)。‘w+‘
- 以【读写】的方式打开文件. 文件会被创建 (如果文件不存在) 或者覆盖 (如果存在)。‘wx+‘
- 类似 ‘w+‘
区别是如果文件存在则操作会失败。‘a‘
- 以【附加】的形式打开文件,即新写入的数据会附加在原来的文件内容之后. 如果文件不存在则会默认创建。‘ax‘
- 类似 ‘a‘
区别是如果文件存在则操作会失败。‘a+‘
- 以【读取】和【附加】的形式打开文件. 如果文件不存在则会默认创建。‘ax+‘
- 类似 ‘a+‘
区别是如果文件存在则操作会失败。mode
用于设置文件模式
(permission and sticky bits), 不过前提是这个文件是已存在的. 默认情况下是 0666,
有可读和可写权限。‘x‘
(对应
open(2) 的O_EXCL标识)
保证 path
是一个新建的文件。
POSIX 操作系统上,即使path
是一个指向不存在位置的符号链接,也会被认定为文件存在。
排除标识在网络文件系统不能确定是否有效。fs.open()
的同步版。buffer
。offset
和length
可以确定从哪个位置开始写入buffer。
position
是参考当前文档光标的位置,然后从该处写入数据。如果typeof
position !== ‘number‘,那么数据会从当前文档位置写入,请看pwrite(2)。written
说明从buffer写入的字节数。fs.createWriteStream
。encoding
是预期得到一个字符串编码。written
表明传入的string需要写入的字符串长度。注意字节的写入跟字符串写入是不一样的。请看Buffer.byteLength.offset
是开始向缓冲区 buffer写入的偏移量。length
是一个整形值,指定了读取的字节数。position
是一个整形值,指定了从哪里开始读取文件,如果position
为null,将会从文件当前的位置读取数据。filename
Stringoptions
Object
encoding
String | Null default = null
flag
String default = ‘r‘
callback
Functionfs.readFile(‘/etc/passwd‘, function (err, data) {
if (err) throw err;
console.log(data);
});
回调函数传递了两个参数 (err,
data)
,
data
就是文件的内容。fs.readFile
的同步版本。
返回文件名为 filename的文件内容。encoding
选项被指定,
那么这个函数返回一个字符串。如果未指定,则返回一个原生buffer。filename
Stringdata
String | Bufferoptions
Object
encoding
String | Null default = ‘utf8‘
mode
Number default = 438
(aka 0666
in
Octal)flag
String default = ‘w‘
callback
Functiondata
可以是一个string,也可以是一个原生buffer。encoding
选项会被忽视如果 data
不是string而是原生buffer。encoding
缺省为 ‘utf8‘。fs.writeFile(‘message.txt‘, ‘Hello Node‘, function (err) {
if (err) throw err;
console.log(‘It\‘s saved!‘);
});
fs.writeFile
的同步版本。filename
Stringdata
String | Bufferoptions
Object
encoding
String | Null default = ‘utf8‘
mode
Number default = 438
(aka 0666
in
Octal)flag
String default = ‘a‘
callback
Functiondata
可以是一个string,也可以是原生buffer。fs.appendFile(‘message.txt‘, ‘data to append‘, function (err) {
if (err) throw err;
console.log(‘The "data to append" was appended to file!‘);
});
稳定性: 2 - 不稳定. 尽可能的话推荐使用 fs.watch 来代替。
监视filename指定的文件的改变.
回调函数 listener
会在文件每一次被访问时被调用。options
应该是包含两个成员persistent和interval的对象,其中persistent值为boolean类型。persistent指定进程是否应该在文件被监视(watch)时继续运行,interval指定了目标文件被查询的间隔,以毫秒为单位。缺省值为{
persistent: true, interval: 5007 }。fs.watchFile(‘message.text‘, function (curr, prev) {
console.log(‘the current mtime is: ‘ + curr.mtime);
console.log(‘the previous mtime was: ‘ + prev.mtime);
});
文件状态对象类型为fs.Stat
。mtime
属性。即curr.mtime和 prev.mtime
.稳定性: 2 - 不稳定. 尽可能的话推荐使用 fs.watch 来代替。
停止监视文件名为 filename的文件.
如果 listener
参数被指定,
会移除在fs.watchFile()函数中指定的那一个listener回调函数。
否则, 所有的 回调函数都会被移除,你将彻底停止监视filename文件。fs.unwatchFile()
时,传递的文件名为未被监视的文件时,不会发生错误,而会发生一个no-op。稳定性: 2 - 不稳定的
观察指定路径的改变,filename路径可以是文件或者目录。改函数返回的对象是 fs.FSWatcher。options
选项被提供那么它应当是包含成员persistent
和recursive
对象, persistent为boolean类型。persistent指定了进程是否“只要文件被监视就继续执行”。recursive表示是否应该关注的所有子目录,或当前目录。这适用于当一个目录是指定的,只有在支持的平台(见下面的说明){
persistent: true, recursive: false }
.(event,
filename)
。其中event是
‘rename‘(重命名)或者 ‘change‘(改变),而 filename则是触发事件的文件名。inotify
。kqueue
。event ports
。ReadDirectoryChangesW
。filename
参数不是在每一个操作系统中都被支持(当下仅在Linux和Windows上支持)。
即便是在支持的系统中,filename
也不能保证在每一次回调都被提供。因此,不要假设filename
参数总会会在
回调函数中提供,在回调函数中添加检测filename
是否为null的if判断语句。fs.watch(‘somedir‘, function (event, filename) {
console.log(‘event is: ‘ + event);
if (filename) {
console.log(‘filename provided: ‘ + filename);
} else {
console.log(‘filename not provided‘);
}
});
callback
传入的参数指明存在
(true) 或者不存在 (false)。示例:fs.exists(‘/etc/passwd‘, function (exists) {
util.debug(exists ? "it‘s there" : "no passwd!");
});
fs.exists()是不合时宜的而且它的存在有历史的原因。从来都不应该有理由来应用在您自己的代码。fs.exists()
和fs.open()
调用的文件之间。当它不存在打开文件和处理错误。
fs.exists函数的同步版。fs.existsSync()
不推荐使用。fs.F_OK
-
文件是显性的调用进程。这是用于确定文件是否存在,但没有说的rwx权限。如果没有指定默认模式。fs.R_OK
- 文件可以被调用进程读取。fs.W_OK
- 文件可以被调用进程写入。fs.X_OK
- 文件可以被调用进程执行。 该状态在windows下无效。最后一个参数是一个回调函数,回调,这是有可能的错误参数调用。如果有任何的可访问性检查失败,错误的观点会密集。下面的示例检查文件/etc/passwd可以读取和写入电流的过程。fs.access(‘/etc/passwd‘, fs.R_OK | fs.W_OK, function(err) {
util.debug(err ? ‘no access!‘ : ‘can read/write‘);
});
fs.stat()
, fs.lstat()
和fs.fstat()
以及他们对应的同步版本返回的对象。stats.isFile()
stats.isDirectory()
stats.isBlockDevice()
stats.isCharacterDevice()
stats.isSymbolicLink()
(仅在与 fs.lstat()
一起使用时合法
)stats.isFIFO()
stats.isSocket()
util.inspect(stats)
将会返回一个类似如下输出的字符串:{ dev: 2114,
ino: 48064969,
mode: 33188,
nlink: 1,
uid: 85,
gid: 100,
rdev: 0,
size: 527,
blksize: 4096,
blocks: 8,
atime: Mon, 10 Oct 2011 23:24:11 GMT,
mtime: Mon, 10 Oct 2011 23:24:11 GMT,
ctime: Mon, 10 Oct 2011 23:24:11 GMT,
birthtime: Mon, 10 Oct 2011 23:24:11 GMT }
请注意atime
, mtime
, birthtime
,和ctime
是 Date 对象的实例。而且在比较这些对象的值时你应当使用合适的方法。
大部分情况下,使用 getTime() 将会返回自 1
January 1970 00:00:00 UTC 以来逝去的毫秒数,
而且这个整形值应该能满足任何比较的使用条件。但是仍然还有一些额外的方法可以用来显示一些模糊的信息。更多细节请查看 MDN
JavaScript Reference 页面。atime
"Access Time" - 文件数据上次被访问的时间.mknod(2)
, utimes(2)
,
and read(2)
等系统调用改变。mtime
"Modified Time" - 文件上次被修改的时间。 会被 mknod(2)
, utimes(2)
,
and write(2)
等系统调用改变。ctime
"Change Time" - 文件状态上次改变的时间。 (inode data modification). 会被 chmod(2)
, chown(2)
,link(2)
, mknod(2)
, rename(2)
, unlink(2)
, utimes(2)
, read(2)
,
and write(2)
等系统调用改变。birthtime
"Birth Time" - 文件被创建的时间。 会在文件被创建时生成。 在一些不提供文件birthtime
的文件系统中,
这个字段会被 ctime
或 1970-01-01T00:00Z
(ie,
unix epoch timestamp 0
)来填充。 在 Darwin 和其他 FreeBSD 系统变体中, 也将 atime
显式地设置成比它现在的 birthtime
更早的一个时间值,这个过程使用了utimes(2)
系统调用。ctime
持有Windows系统的 birthtime
值.
注意在v.0.12版本中,ctime
不再是"creation
time", 而且在Unix系统中,他从来都不是。options
是一个包含下列缺省值的对象:{ flags: ‘r‘,
encoding: null,
fd: null,
mode: 0666,
autoClose: true
}
options
可以提供 start
和 end
值用于读取文件内的特定范围而非整个文件。 start
和end
都是包含在范围内的(inclusive,
可理解为闭区间)并且以 0 开始。 encoding
可选为 ‘utf8‘
, ‘ascii‘
,
或者‘base64‘
。fd
指定,ReadStream
会忽略路径参数path
,将使用指定的文件描述符。这意味着没有公开的事件将被触发。autoClose
为
false 则即使在发生错误时也不会关闭文件描述符 (file descriptor)。 此时你需要负责关闭文件,避免文件描述符泄露 (leak)。 如果 autoClose
为
true (缺省值), 当发生 error
或者 end事件时,文件描述符会被自动释放。fs.createReadStream(‘sample.txt‘, {start: 90, end: 99});
ReadStream
是一个可读的流(Readable
Stream).
fd
{整形} ReadStream 所使用的文件描述符。Writable
Stream
)。options
是一个包含下列缺省值的对象:{ flags: ‘w‘,
encoding: null,
fd: null,
mode: 0666 }
options
也可以包含一个 start
选项用于指定在文件中开始写入数据的位置。
修改而不替换文件需要 flags
的模式指定为
r+而不是默值的
w。ReadStream
,如果指定fd,可写流会忽略路径参数,将使用指定的文件描述符。这意味着没有公开的事件将被触发。fd
{整形} WriteStream 所使用的文件描述符。fs.watch()
返回的对象类型。event
{字符串} fs 改变的类型filename
{字符串} 改变的文件名 (if relevant/available)error
{Error 对象}原文:http://blog.csdn.net/livialiu1234/article/details/43919461