[WinAPI] API 6 [操作驱动器挂载点]

时间:2023-03-09 07:00:07
[WinAPI] API 6 [操作驱动器挂载点]

驱动器挂载点,又可以称作卷挂载点。挂载点实际上是操作系统或者用户设置的,用来进入一个逻辑驱动器或者卷的入口。在设置了卷的挂载点后,用户或者应用程序可以使用卷标或者指定的挂载点来进入卷。比如在“C:\”下设置了一个“E\”:卷的挂载点mnt,那么打开“E:\”和打开“C:\mnt”实际上都是进入“E:\”卷。
一般可以用FindFirstVolumeMountPoint系列的API来找到一个卷的所有挂载点;用GetVolumeNameForVolumeMountPoint来获取指定挂载点所指向的卷名,卷名形式为"\\?\Volume{GUID}\”;用SetVolumeMountPoint来设置新的挂载点。

通过系统的磁盘管理功能可以设置卷的挂载点:

◇“我的电脑”图标右键菜单中选择“管理”。
◇弹出“计算机管理”窗口,选择“磁盘管理”。
◇选中需要挂载的卷,在右键菜单中选择“更改驱动 器名和路径”。
◇在弹出的对话框中单击“添加”按钮,选择“装入 以下空白NTFS文件夹”。
◇选择需要将卷挂载入的文件夹(空白),单击“确定”按钮。
◇卷就被装入文件夹中,之后就可以和访问文件夹一个访问这个卷了。

(1)FindFirstVolumeMountPoint.
获取指定卷的第一个挂载点

◇参数
lpszRootPathName:输入参数,指定要查找的卷名,必须以反斜杠结尾。
lpszVolumeMountPoint:输出参数,找到的第一个挂载点。
cchBufferLength.输入参数,用来储存输出挂载点的缓存的大小。
◇返回值
返回HANDLE值,为一个查找句柄,FindNextVolumeMountPoint用该句柄查找下一个挂载点。错误时值为INVALLD HANDLE VALUE,以用GetLastError()函数获取更详细的错误信息。

(2) FindNextVolumeMountPoint
查找指定卷的后继挂载点

◇参数
hFindVolumeMountPoint:输入参数,查找句柄,由FindFirstVolumeMountPoint获取。
lpszVolumeMountPoint:输出参数,找到的后继挂载点。
cchBufferLength:输入参数,用来储存输出挂载点的缓存的大小。
◇返回值
返回BOOL值,表示查找是否成功,失败并且GetLastError函数返回ERROR NO_ MORE
FILE$代码时表示已经查找完所有挂载点。

(3)FindVolumeMountPointClose.
关闭FindVolumeMountPointClose打开的卷句柄

◇参数
hFindVolumeMountPoint:要关闭的挂载点查找句柄。
◇返回值

(4)GetVolumeNameForVolumeMountPoint。
根据指定的挂载点获取相应的卷设备名

◇参数
lpszVolumeMountPoint:输入参数,指定需要查找挂载点或者根目录,以反斜杠结束。
lpszVolumeName:输出参数,挂载点对应的卷设备名,形式为“\\?\Volume{GUID}\”。

cchBufferLength:输入参数,用来储存输出设备名的缓存大小。
◇返回值
返回BOOL值,表示函数是否成功,同样可以用GetLastError函数获取更详细的错误信息。

(5)SetVolumeMountPc
将指定卷挂载到指定挂载点处

◇参数
lpszVolumeMountPoint:输入参数,指定的挂载点,挂载点必须为一个根路径或者一个在现有卷上的路径,必须以反斜杠结束。
lpszVolumeName:输入参数,卷设备名,形式为“\\?\Volume{GUID}\”。
◇返回值
返回BOOL值表示函数是否成功,同样可以用GetLastError()函数获取更详细的错误信息。

 #define _WIN32_WINNT 0x0501
#include <windows.h>
#include <stdio.h>
#include <tchar.h>
#define BUFSIZE MAX_PATH
#define FILESYSNAMEBUFSIZE MAX_PATH /* ************************************
* ProcessVolumeMountPoint
* 功能 列举挂载点
**************************************/
BOOL ProcessVolumeMountPoint (HANDLE hPt,
TCHAR *PtBuf, DWORD dwPtBufSize,
TCHAR *Buf)
{
BOOL bFlag; // 结果
TCHAR Path[BUFSIZE]; // 全路径
TCHAR Target[BUFSIZE]; // 挂载点设备 printf ("\tVolume mount point found is \"%s\"\n", PtBuf); lstrcpy (Path, Buf);
lstrcat (Path, PtBuf); bFlag = GetVolumeNameForVolumeMountPoint(Path,Target,BUFSIZE); if (!bFlag)
printf ("\tAttempt to get volume name for %s failed.\n", Path);
else
printf ("\tTarget of the volume mount point is %s.\n", Target); bFlag = FindNextVolumeMountPoint(hPt,PtBuf,dwPtBufSize);
return (bFlag);
}
/* ************************************
* ProcessVolume
* 功能 判断卷类型,列举挂载点
**************************************/
BOOL ProcessVolume (HANDLE hVol, TCHAR *Buf, DWORD iBufSize)
{
BOOL bFlag; // 返回标志
HANDLE hPt; // 卷句柄
TCHAR PtBuf[BUFSIZE]; // 挂载点路径
DWORD dwSysFlags; // 文件系统标记
TCHAR FileSysNameBuf[FILESYSNAMEBUFSIZE]; printf ("Volume found is \"%s\".\n", Buf); // 是否NTFS
GetVolumeInformation( Buf, NULL, , NULL, NULL,
&dwSysFlags, FileSysNameBuf,
FILESYSNAMEBUFSIZE); if (! (dwSysFlags & FILE_SUPPORTS_REPARSE_POINTS))
{
printf ("\tThis file system does not support volume mount points.\n");
}
else
{
// 本卷中的挂载点
hPt = FindFirstVolumeMountPoint(
Buf, // 卷的跟跟踪
PtBuf, // 挂载点路径
BUFSIZE
); if (hPt == INVALID_HANDLE_VALUE)
{
printf ("\tNo volume mount points found!\n");
}
else
{
// 处理挂载点
bFlag = ProcessVolumeMountPoint (hPt,
PtBuf,
BUFSIZE,
Buf);
// 循环
while (bFlag)
bFlag =
ProcessVolumeMountPoint (hPt, PtBuf, BUFSIZE, Buf);
// 结束
FindVolumeMountPointClose(hPt);
}
} // 下一个
bFlag = FindNextVolume(
hVol, Buf, iBufSize); return (bFlag);
}
/* ************************************
* int GetMountPoint(void)
* 功能 获取挂载点
**************************************/
int GetMountPoint(void)
{
TCHAR buf[BUFSIZE]; // 卷标识符
HANDLE hVol; // 卷句柄
BOOL bFlag; // 结果标志 printf("Volume mount points info of this computer:\n\n");
// 打开卷
hVol = FindFirstVolume (buf, BUFSIZE );
if (hVol == INVALID_HANDLE_VALUE)
{
printf ("No volumes found!\n");
return (-);
} bFlag = ProcessVolume (hVol, buf, BUFSIZE);
while (bFlag)
{
bFlag = ProcessVolume (hVol, buf, BUFSIZE);
} bFlag = FindVolumeClose( hVol );
return (bFlag);
} /* ************************************
* void Usage (PCHAR argv)
* 功能 使用方法
**************************************/
void Usage (PCHAR argv)
{
printf( "\n\n\t%s, mount a volume at a mount point.\n", argv );
printf( "\tFor example, \"mount D:\\mnt\\drives\\ E:\\\"\n" );
} /* ************************************
* main
* 功能 入口函数
**************************************/
int main( int argc, PCHAR argv[] )
{
BOOL bFlag;
CHAR Buf[BUFSIZE]; if( argc != )
{
GetMountPoint();
Usage( argv[] );
return( - );
} bFlag = GetVolumeNameForVolumeMountPointA(
argv[], // 输入挂载点或目录
Buf, // 输出卷名
BUFSIZE
); if (bFlag != TRUE)
{
printf( "Retrieving volume name for %s failed.\n", argv[] );
return (-);
} printf( "Volume name of %s is %s\n", argv[], Buf );
bFlag = SetVolumeMountPointA(
argv[], // 挂载点
Buf // 需要挂载的卷
); if (!bFlag)
{
printf ("Attempt to mount %s at %s failed. error code is\n",
argv[], argv[], GetLastError());
} return (bFlag);
}