4.2 使用FindFirstVolume系列函数遍历驱动器信息

效果

和上一个方法区别在于如红框处,驱动名返回的是以\\?\volume{GUID}形式,并且多出了之前没有的一个系统保留磁盘

4.2 使用FindFirstVolume系列函数遍历驱动器信息_第1张图片

源码

#include

#include

#define _WIN32_WINNT 0x0601

#define BUFSIZE 1024//文件系统名称缓冲区的长度

BOOL GetDirverInfo(LPSTR szDrive);//声明函数

void main(int argc, PCHAR argv[]){

TCHAR buf[BUFSIZE];//卷标信息

HANDLE hVol;//卷遍历句柄

BOOL bFlag;//标志

hVol = FindFirstVolume(buf, BUFSIZE);//查找主机中的第一个驱动器,返回查找句柄

if (hVol == INVALID_HANDLE_VALUE){

printf("no volume found\n");

return (-1);

}

GetDirverInfo(buf);

while (FindNextVolume(hVol, buf, BUFSIZE)){//根据FindFirstVolume返回的句柄, 查找主机中后续的逻辑驱动器

GetDirverInfo(buf);

}

bFlag = FindVolumeClose(hVol);

getchar();

return bFlag;

}

//获取驱动器信息

//参数:要获取的驱动器根路径,如 C:\ */

BOOL GetDirverInfo(LPSTR szDrive){

UINT uDriveType;//驱动器的类型

DWORD dwVolumeSerialNumber;//卷序号

DWORD dwMaximumComponentLength;//最大长度

DWORD dwFileSystemFlags;//标志

CHAR szFileSystemNameBuffer[MAX_PATH];//接收文件系统名称的缓冲区,例如FAT文件系统或NTFS文件系统

CHAR szDriveName[MAX_PATH];//卷名的缓冲区

printf("驱动器: %s\n", szDrive);

uDriveType = GetDriveType(szDrive);//判断驱动器的类型

switch (uDriveType){

case DRIVE_UNKNOWN:

printf("不能确定驱动器类型\n");

break;

case DRIVE_NO_ROOT_DIR:

printf("根路径无效,例如:在该路径上备用安装卷\n");

break;

case DRIVE_REMOVABLE:

printf("驱动器是一种可移动介质的类型,例如:软盘驱动器或可移动硬盘\n");

break;

case DRIVE_FIXED:

printf("驱动器是一种不能移动的类型,例如:固定硬盘驱动器\n");

break;

case DRIVE_REMOTE:

printf("驱动器是远程(网络)驱动器\n");

break;

case DRIVE_CDROM:

printf("驱动器是一个CD-ROM驱动器\n");

case DRIVE_RAMDISK:

printf("驱动器是RAM(内存)磁盘\n");

break;

default:

break;

}

if (!GetVolumeInformation(//获得磁盘卷的信息

szDrive,//指向包含要描述的卷的根目录的字符串的指针

szDriveName,//指向接收指定卷名称的缓冲区的指针

MAX_PATH,//缓冲区的长度,TCHAR中最大缓冲区的大小是MAX_PATH + 1

&dwVolumeSerialNumber,//指向接收卷序号的变量的指针

&dwMaximumComponentLength,//指向一个变量的指针.用来保存文件系统支持的最大文件名长度

&dwFileSystemFlags,//指向接收与指定文件系统关联的标志的变量的指针

szFileSystemNameBuffer,//指向缓冲区的指针

BUFSIZE//文件系统名称缓冲区的长度

)){

//MessageBox(NULL, "xxx", "xxx", MB_OK);

return FALSE;

}

if (0 != lstrlen(szDriveName)){//如果卷名不为空

printf("驱动器名称: %s\n", szDriveName);

}

printf("卷的序列号: %u\n", dwVolumeSerialNumber);

printf("最大组件长度: %u\n", dwMaximumComponentLength);

printf("系统类型: %s\n", szFileSystemNameBuffer);

if (dwFileSystemFlags & FILE_CASE_PRESERVED_NAMES){

printf("指定的卷支持在磁盘上保存名称时保留文件名的大小写。\n");

}

if (dwFileSystemFlags & FILE_CASE_SENSITIVE_SEARCH){

printf("指定的卷支持区分大小写的文件名。\n");

}

if (dwFileSystemFlags & FILE_FILE_COMPRESSION){

printf("指定的卷支持基于文件的压缩。\n");

}

if (dwFileSystemFlags & FILE_NAMED_STREAMS){

printf("指定的卷支持命名流。\n");

}

if (dwFileSystemFlags & FILE_PERSISTENT_ACLS){

printf("指定的卷保留并强制访问控制列表(ACL)。\n");

}

if (dwFileSystemFlags & FILE_READ_ONLY_VOLUME){

printf("指定的卷是只读的。\n");

}

if (dwFileSystemFlags & FILE_SEQUENTIAL_WRITE_ONCE){

printf("指定的卷支持单个顺序写入。\n");

}

if (dwFileSystemFlags & FILE_SUPPORTS_ENCRYPTION){

printf("指定的卷支持加密文件系统(EFS)。\n");

}

if (dwFileSystemFlags & FILE_SUPPORTS_EXTENDED_ATTRIBUTES){

printf("指定的卷支持扩展属性。\n");

}

if (dwFileSystemFlags & FILE_SUPPORTS_HARD_LINKS){

printf("指定的卷支持硬链接。\n");

}

if (dwFileSystemFlags & FILE_SUPPORTS_OBJECT_IDS){

printf("指定的卷支持对象标识符。\n");

}

if (dwFileSystemFlags & FILE_SUPPORTS_OPEN_BY_FILE_ID){

printf("文件系统支持FileID打开。\n");

}

if (dwFileSystemFlags & FILE_SUPPORTS_REPARSE_POINTS){

printf("指定的卷支持重解析点。\n");

}

if (dwFileSystemFlags & FILE_SUPPORTS_SPARSE_FILES){

printf("指定的卷支持稀疏文件。\n");

}

if (dwFileSystemFlags & FILE_SUPPORTS_TRANSACTIONS){

printf("指定的卷支持事务。\n");

}

if (dwFileSystemFlags & FILE_SUPPORTS_USN_JOURNAL){

printf("指定的卷支持更新序列号(USN)日志。\n");

}

if (dwFileSystemFlags & FILE_UNICODE_ON_DISK){

printf("指定的卷在文件名中显示在磁盘上时支持Unicode。\n");

}

if (dwFileSystemFlags & FILE_VOLUME_IS_COMPRESSED){

printf("指定的卷是一个压缩卷。\n");

}

if (dwFileSystemFlags & FILE_VOLUME_QUOTAS){

printf("指定的卷支持磁盘配额。\n");

}

return TRUE;

}

你可能感兴趣的:(4.2 使用FindFirstVolume系列函数遍历驱动器信息)