1、获取文件信息
每个文件都有一组细节,我们可以使用Node.js进行检查。特别是使用fs模块提供的stat()方法。
1. const fs = require('fs'); 2. fs.stat('/Users/joe/test.txt', (err, stats) => { 3. if (err) { 4. console.error(err); 5. } 6. console.error(); 7. // 我们可以访问文件的stats 8. });
返回的stats对象
1. Stats { 2. dev: 2114, // 包含文件的设备的数字标识符。 3. ino: 48064969, // 文件的特定于文件系统的“Inode”编号。 4. mode: 33188, // 描述文件类型和模式的位字段。 5. nlink: 1, // 该文件存在的硬链接数。 6. uid: 85, // 拥有文件(POSIX)的用户的数字用户标识符。 7. gid: 100, // 拥有文件(POSIX)的组的数字组标识符。 8. rdev: 0, // 如果文件表示设备,则为数字设备标识符。 9. size: 527, // 文件的大小(以字节为单位)。 10. blksize: 4096, // 用于i/o操作的文件系统块大小。 11. blocks: 8, // 为此文件分配的块数。 12. atimeMs: 1318289051000.1, // 最后一次访问此文件的时间戳(以毫秒为单位)。 13. mtimeMs: 1318289051000.1, // 最后一次修改此文件的时间戳(以毫秒为单位) 14. ctimeMs: 1318289051000.1, // 最后一次更改文件状态的时间戳(以毫秒为单位) 15. birthtimeMs: 1318289051000.1, // 此文件创建时间的时间戳(以毫秒为单位) 16. atime: Mon, 10 Oct 2011 23:24:11 GMT, // 指示上次访问此文件的时间。 17. mtime: Mon, 10 Oct 2011 23:24:11 GMT, // 上次修改此文件的时间。 18. ctime: Mon, 10 Oct 2011 23:24:11 GMT, // 上次更改文件状态的时间。 19. birthtime: Mon, 10 Oct 2011 23:24:11 GMT // 此文件创建时间的时间。 20. }
Node.js还提供了一个sync方法,它会阻塞线程,直到文件统计数据准备好:
1. const fs = require('fs'); 2. try { 3. const stats = fs.statSync('/Users/joe/test.txt'); 4. } catch (err) { 5. console.error(err); 6. }
文件信息包含在stats变量中。我们可以使用统计数据提取什么样的信息?
- 如果文件是目录或文件,请使用stats.isFile()和stats.isDirectory()
- 如果文件是使用stats.isSymbolicLink()的符号链接
- 使用stats.size的文件大小(以字节为单位)。
1. const fs = require('fs'); 2. fs.stat('/Users/joe/test.txt', (err, stats) => { 3. if (err) { 4. console.error(err); 5. return; 6. } 7. console.log(stats.isFile()); // true 8. console.log(stats.isDirectory()); // false 9. console.log(stats.isSymbolicLink()); // false 10. console.log( stats.size) // 1024000 //= 1MB 11. });
如果您愿意,也可以使用fs/promises 模块提供的基于promise的fsPromises.stat()方法:
1. const fs = require('fs/promises'); 2. async function example() { 3. try { 4. const stats = await fs.stat('/Users/joe/test.txt'); 5. stats.isFile(); // true 6. stats.isDirectory(); // false 7. stats.isSymbolicLink(); // false 8. stats.size; // 1024000 //= 1MB 9. } catch (err) { 10. console.log(err); 11. } 12. } 13. example();
2、文件路径
系统中的每个文件都有一个路径。在Linux和macOS上,路径可能看起来像:/users/joe/file.txt,而Windows计算机不同,并且具有如下结构:C:\users\joe \file.txt
在应用程序中使用路径时需要注意,因为必须考虑到这一差异。
您可以使用const-path=require('path')将此模块包含在文件中;你可以开始使用它的方法。
2.1 从路径中获取信息
给定一条路径,您可以使用以下方法从中提取信息:
- dirname:获取文件的父文件夹
- basename:获取文件名部分
- extname:获取文件扩展名
1. const notes = '/users/joe/notes.txt'; 2. path.dirname(notes); // /users/joe 3. path.basename(notes); // notes.txt 4. path.extname(notes); // .txt
通过为basename指定第二个参数,可以获得不带扩展名的文件名:
path.basename(notes, path.extname(notes)); // notes
2.2 使用路径
您可以使用path.join()连接路径的两个或多个部分:
1. const name = 'joe'; 2. path.join('/', 'users', name, 'notes.txt'); // '/users/joe/notes.txt'
您可以使用path.resolve()获得相对路径的绝对路径计算:
1. // '/Users/joe/joe.txt' 查找用户目录下的文件 2. path.resolve('joe.txt');
Node.js将/joe.txt附加到当前工作目录中。如果指定第二个参数文件夹,resolve将使用第一个作为第二个的基础:
1. // '/Users/joe/tmp/joe.txt' 用户目录下的tmp文件夹下的goe.txt 2. path.resolve('tmp', 'joe.txt');
如果第一个参数以斜线开头,则意味着它是一个绝对路径:
path.resolve('/etc', 'joe.txt'); // '/etc/joe.txt'
path.normalize()是另一个有用的函数,当它包含这样的相对修饰符时,它将尝试计算实际路径。或者 .. 或者 //:
../ 实际上就是返回上级目录
path.normalize('/users/joe/..//test.txt'); // '/users/test.txt'
3、文件或目录的权限
以下通过一个示例,看下异步更改权限:
1. const fs = require('fs'); 2. 3. fs.chmod('my_file.txt', 0o775, (err) => { 4. if (err) throw err; 5. console.log('"my_file.txt"权限发生更改!'); 6. });
3.1 文件模式
在mode和fs.chmod()中使用的fs.chmodSync()参数 methods是一个数字位掩码,它是使用以下逻辑OR创建的 常量:
常数 | 八进制 | 说明 |
fs.constants.S_IRUSR |
0o400 |
由所有者读取 |
fs.constants.S_IWUSR |
0o200 |
由所有者写入 |
fs.constants.S_IXUSR |
0o100 |
按所有者可执行/搜索 |
fs.constants.S_IRGRP |
0o40 |
按组读取 |
fs.constants.S_IWGRP |
0o20 |
按组写入 |
fs.constants.S_IXGRP |
0o10 |
按组可执行/搜索 |
fs.constants.S_IROTH |
0o4 |
其他只读 |
fs.constants.S_IWOTH |
0o2 |
其他可写 |
fs.constants.S_IXOTH |
0o1 |
其他可执行/搜索 |
构造mode的一个更简单的方法是使用一个序列 八进制数字(例如,765)。最左边的数字(示例中的7)指定 文件所有者的权限。中间的数字(示例中的6), 指定组的权限。最右边的数字(示例中的5), 指定其他人的权限。
数字 | 说明 |
7 |
读、写和执行 |
6 |
读写 |
5 | 读取并执行 |
4 | 只读 |
3 | 写入和执行 |
2 | 只写 |
1 |
只执行 |
0 |
无权限 |
例如,八进制值0o765表示:
- 所有者可以读取、写入和执行文件。
- 该组可以读取和写入文件。
- 其他人可以读取和执行该文件。
当在需要文件模式的情况下使用原始数字时,任何大于 0o777可能会导致不受支持的特定于平台的行为 始终如一因此,像S_ISVTX、S_ISGID或S_ISUID这样的常量不会在fs. constants中公开。