效果
和上一个方法区别在于如红框处,驱动名返回的是以\\?\volume{GUID}形式,并且多出了之前没有的一个系统保留磁盘
源码
#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;
}