node.js中的fs.open方法使用说明
方法说明:
以异步的方式打开文件。
在POSIX系统中,path被认为是默认存在的(即使该路径下的文件是不存在的)
flag标识可能或可能不在网络文件系统下运行。
语法:
fs.open(path,flags,[mode],[callback(err,fd)])
由于该方法属于fs模块,使用前需要引入fs模块(varfs=require(“fs”))
接收参数:
path 文件路径
flags 可以是以下的值
'r'- 以读取模式打开文件。 'r+'-以读写模式打开文件。 'rs'-使用同步模式打开并读取文件。指示操作系统忽略本地文件系统缓存。 'rs+'-以同步的方式打开,读取并写入文件。 注意:这不是让fs.open变成同步模式的阻塞操作。如果想要同步模式请使用fs.openSync()。 'w'-以读取模式打开文件,如果文件不存在则创建 'wx'-和'w'模式一样,如果文件存在则返回失败 'w+'-以读写模式打开文件,如果文件不存在则创建 'wx+'-和'w+'模式一样,如果文件存在则返回失败 'a'-以追加模式打开文件,如果文件不存在则创建 'ax'-和'a'模式一样,如果文件存在则返回失败 'a+'-以读取追加模式打开文件,如果文件不存在则创建 'ax+'-和'a+'模式一样,如果文件存在则返回失败 mode 用于创建文件时给文件制定权限,默认0666
callback 回调函数会传递一个文件描述符fd,和一个异常err
例子:
varfs=require('fs'); fs.open('/path/demo1.txt','a',function(err,fd){ if(err){ throwerr; } fs.futimes(fd,1388648322,1388648322,function(err){ if(err){ throwerr; } console.log('futimescomplete'); fs.close(fd,function(){ console.log('Done'); }); }); });
源码:
fs.open=function(path,flags,mode,callback){ callback=makeCallback(arguments[arguments.length-1]); mode=modeNum(mode,438/*=0666*/); if(!nullCheck(path,callback))return; binding.open(pathModule._makeLong(path), stringToFlags(flags), mode, callback); };