FILE_STAT_BASIC_INFORMATION结构 (ntifs.h)

FILE_STAT_BASIC_INFORMATION 包含有关文件的基本元数据。

语法

typedef struct _FILE_STAT_BASIC_INFORMATION {
  LARGE_INTEGER FileId;
  LARGE_INTEGER CreationTime;
  LARGE_INTEGER LastAccessTime;
  LARGE_INTEGER LastWriteTime;
  LARGE_INTEGER ChangeTime;
  LARGE_INTEGER AllocationSize;
  LARGE_INTEGER EndOfFile;
  ULONG         FileAttributes;
  ULONG         ReparseTag;
  ULONG         NumberOfLinks;
  ULONG         DeviceType;
  ULONG         DeviceCharacteristics;
  ULONG         Reserved;
  LARGE_INTEGER VolumeSerialNumber;
  FILE_ID_128   FileId128;
} FILE_STAT_BASIC_INFORMATION, *PFILE_STAT_BASIC_INFORMATION;

成员

FileId

指定文件的标识符。

CreationTime

指定文件的创建时间。

LastAccessTime

指定上次访问文件时。

LastWriteTime

指定上次写入文件的时间。

ChangeTime

指定上次更改文件的时间。

AllocationSize

文件分配大小(以字节为单位)。 通常,此值是基础物理设备的扇区或群集大小的倍数。

EndOfFile

绝对新的文件结束位置作为字节偏移量从文件开头。 EndOfFile 指定文件末尾的字节偏移量。 由于此值从零开始,因此它实际上引用了文件中的第一个免费字节。 换句话说,EndOfFile 是紧随文件中最后一个有效字节之后的字节的偏移量。

FileAttributes

文件属性,可以是下列任何有效组合:

属性 价值
FILE_ATTRIBUTE_READONLY 0x00000001
FILE_ATTRIBUTE_HIDDEN 0x00000002
FILE_ATTRIBUTE_SYSTEM 0x00000004
FILE_ATTRIBUTE_DIRECTORY 0x00000010
FILE_ATTRIBUTE_ARCHIVE 0x00000020
FILE_ATTRIBUTE_NORMAL 0x00000080

ReparseTag

指定重新分析点的标记。 有关详细信息,请参阅 关于重新分析点

NumberOfLinks

指定指向文件的链接数。

DeviceType

在驱动程序调用 IoCreateDevice 时设置,适合基础设备的类型。 有关详细信息,请参阅 指定设备类型

DeviceCharacteristics

设备特征。 有关相关值的说明,请参阅 DEVICE_OBJECT

Reserved

保留供系统使用。

VolumeSerialNumber

文件所在的卷的序列号。

FileId128

文件的 128 字节文件引用号。 此数字由文件系统生成并分配给文件。

言论

可通过以下任一方式查询此信息:

  • 调用 ZwQueryDirectoryFile,将 FileStatBasicInformation 作为 fileInformation Class 的值传递,并将调用方分配的结构化缓冲区作为 fileInformation的值传递 FILE_ID_EXTD_DIR_INFORMATION结构化缓冲区。

  • 使用主要函数代码 IRP_MJ_DIRECTORY_CONTROL 和次要函数代码IRP_MN_QUERY_DIRECTORY创建 IRP。

查询此信息不需要特定的访问权限。

文件引用编号(也称为文件 ID)保证仅在静态文件系统中是唯一的。 随着时间的推移,它们不一定是唯一的,因为文件系统可以自由重复使用它们。 它们也不能保证保持不变。 例如,FAT 文件系统从磁盘上文件目录条目记录(DIRENT)的字节偏移量生成文件的文件引用号。 碎片整理可以更改此字节偏移量。 因此,FAT 文件引用编号可能会随时间而变化。

所有日期和时间都采用绝对系统时间格式。 绝对系统时间是自 1601 年初以来的 100 纳秒间隔数。

此结构必须在 LONGLONG(8 字节)边界上对齐。 如果缓冲区包含两个或多个这些结构,则每个条目中的 NextEntryOffset 值(最后一个除外)位于 8 字节边界上。

要求

要求 价值
最低支持的客户端 Windows 11 版本 24H2
标头 ntifs.h

另请参阅

FILE_INFORMATION_CLASS

ZwQueryInformationByName