FILE_NOTIFY_EXTENDED_INFORMATION-Struktur (ntifs.h)
FILE_NOTIFY_EXTENDED_INFORMATION stellt Informationen zu einer Verzeichnisänderung als Reaktion auf eine IRP_MJ_DIRECTORY_CONTROL-Anforderung mit einem IRP_MN_NOTIFY_CHANGE_DIRECTORY Nebenfunktionscode bereit, wenn DIRECTORY_NOTIFY_INFORMATION_CLASS DirectoryNotifyExtendedInformation ist.
Syntax
typedef struct _FILE_NOTIFY_EXTENDED_INFORMATION {
ULONG NextEntryOffset;
ULONG Action;
LARGE_INTEGER CreationTime;
LARGE_INTEGER LastModificationTime;
LARGE_INTEGER LastChangeTime;
LARGE_INTEGER LastAccessTime;
LARGE_INTEGER AllocatedLength;
LARGE_INTEGER FileSize;
ULONG FileAttributes;
union {
ULONG ReparsePointTag;
ULONG EaSize;
} DUMMYUNIONNAME;
LARGE_INTEGER FileId;
LARGE_INTEGER ParentFileId;
ULONG FileNameLength;
WCHAR FileName[1];
} FILE_NOTIFY_EXTENDED_INFORMATION, *PFILE_NOTIFY_EXTENDED_INFORMATION;
Member
NextEntryOffset
Die Anzahl der Bytes, die übersprungen werden müssen, um zum nächsten Datensatz zu gelangen. Der Wert 0 gibt an, dass dies der letzte Datensatz ist.
Action
Der Typ der Änderung, die aufgetreten ist. Dieser Member kann einer der folgenden Werte sein.
Wert | Bedeutung |
---|---|
FILE_ACTION_ADDED (0x00000001) | Dem Verzeichnis wurde eine Datei hinzugefügt. |
FILE_ACTION_REMOVED (0x00000002) | Eine Datei wurde aus dem Verzeichnis entfernt. |
FILE_ACTION_MODIFIED (0x00000003) | Das Verzeichnis wurde geändert. Dies kann eine Änderung des Zeitstempels oder der Attribute sein. |
FILE_ACTION_RENAMED_OLD_NAME (0x00000004) | Das Verzeichnis wurde umbenannt, und dies ist der alte Name. |
FILE_ACTION_RENAMED_NEW_NAME (0x00000005) | Das Verzeichnis wurde umbenannt, und dies ist der neue Name. |
CreationTime
Das Datum und die Uhrzeit, zu dem das Verzeichnis oder die Datei erstellt und dem Dateisystem hinzugefügt wurde.
LastModificationTime
Das Datum und die Uhrzeit der letzten Änderung des Inhalts des Verzeichnisses oder der Datei im Dateisystem.
LastChangeTime
Das Datum und die Uhrzeit der letzten Änderung der Metadaten oder des Inhalts des Verzeichnisses oder der Datei im Dateisystem.
LastAccessTime
Das Datum und die Uhrzeit des letzten Zugriffs auf das Verzeichnis oder die Datei im Dateisystem.
AllocatedLength
Die zugeordnete Größe der Datei in Bytes.
FileSize
Die neue Größe des Verzeichnisses oder der Datei in Bytes oder die alte Größe, wenn die Größe unverändert ist.
FileAttributes
Dateiattribute, die eine beliebige gültige Kombination der folgenden sein können:
- FILE_ATTRIBUTE_READONLY
- FILE_ATTRIBUTE_HIDDEN
- FILE_ATTRIBUTE_SYSTEM
- FILE_ATTRIBUTE_DIRECTORY
- FILE_ATTRIBUTE_ARCHIVE
- FILE_ATTRIBUTE_NORMAL
- FILE_ATTRIBUTE_TEMPORARY
- FILE_ATTRIBUTE_COMPRESSED
DUMMYUNIONNAME
DUMMYUNIONNAME.ReparsePointTag
Das Bezeichnertag eines Analysepunkts für das Verzeichnis oder die Datei.
DUMMYUNIONNAME.EaSize
Kombinierte Länge der erweiterten Attribute (EA) für die Datei in Bytes.
FileId
Der Bezeichner des Verzeichnisses oder der Datei. Diese Nummer wird generiert und der Datei vom Dateisystem zugewiesen.
ParentFileId
Der Bezeichner des übergeordneten Verzeichnisses der Datei.
FileNameLength
Die Größe des Dateinamenteils des Datensatzes in Bytes. Dieser Wert enthält kein beendendes NULL-Zeichen.
FileName[1]
Ein Feld mit variabler Länge, das den Dateinamen relativ zum Verzeichnishandle enthält. Der Dateiname hat das Unicode-Zeichenformat und ist nicht null-beendet.
Anforderungen
Anforderung | Wert |
---|---|
Header | ntifs.h |