4.1 使用GetLogicalDriveStrings获取驱动

2017-09-14  本文已影响0人  f675b1a02698

效果

源码

#include

#include

#include

//不要用Unicode编码,反正我用这个编码后不能正确执行

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

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

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

CHAR szLogicalDriveStrings[BUFSIZE];//保存所有卷缓存的空间

PCHAR szDrive;

ZeroMemory(szLogicalDriveStrings, BUFSIZE);//将指定空间用0填充

GetLogicalDriveStrings(BUFSIZE - 1, szLogicalDriveStrings);//保存类似于 C:\\0D:\\0\0...

szDrive = (PCHAR)szLogicalDriveStrings;//指向保存了所有卷缓存的空间

do{

if (!GetDirverInfo(szDrive)){

printf("获取信息错误: %d\n", GetLastError());

}

szDrive += (lstrlen(szDrive) + 1);//看不懂...

} while (*szDrive != '\x00');//指向的值不是0就循环

getchar();

}

//获取驱动器信息

//参数:要获取的驱动器根路径,如 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;

}

上一篇 下一篇

猜你喜欢

热点阅读