[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()函数获取更详细的错误信息。

  1 #define _WIN32_WINNT 0x0501
  2 #include <windows.h>
  3 #include <stdio.h>
  4 #include <tchar.h>
  5 #define BUFSIZE            MAX_PATH
  6 #define FILESYSNAMEBUFSIZE MAX_PATH
  7
  8 /* ************************************
  9 * ProcessVolumeMountPoint
 10 * 功能 列举挂载点
 11 **************************************/
 12 BOOL ProcessVolumeMountPoint (HANDLE hPt,
 13                               TCHAR *PtBuf, DWORD dwPtBufSize,
 14                               TCHAR *Buf)
 15 {
 16     BOOL bFlag;      // 结果
 17     TCHAR Path[BUFSIZE]; // 全路径
 18     TCHAR Target[BUFSIZE];   // 挂载点设备
 19
 20     printf ("\tVolume mount point found is \"%s\"\n", PtBuf);
 21
 22     lstrcpy (Path, Buf);
 23     lstrcat (Path, PtBuf);
 24
 25     bFlag = GetVolumeNameForVolumeMountPoint(Path,Target,BUFSIZE);
 26
 27     if (!bFlag)
 28         printf ("\tAttempt to get volume name for %s failed.\n", Path);
 29     else
 30         printf ("\tTarget of the volume mount point is %s.\n", Target);
 31
 32     bFlag = FindNextVolumeMountPoint(hPt,PtBuf,dwPtBufSize);
 33     return (bFlag);
 34 }
 35 /* ************************************
 36 * ProcessVolume
 37 * 功能 判断卷类型,列举挂载点
 38 **************************************/
 39 BOOL ProcessVolume (HANDLE hVol, TCHAR *Buf, DWORD iBufSize)
 40 {
 41     BOOL bFlag;           // 返回标志
 42     HANDLE hPt;           // 卷句柄
 43     TCHAR PtBuf[BUFSIZE]; // 挂载点路径
 44     DWORD dwSysFlags;     // 文件系统标记
 45     TCHAR FileSysNameBuf[FILESYSNAMEBUFSIZE];
 46
 47     printf ("Volume found is \"%s\".\n", Buf);
 48
 49     // 是否NTFS
 50     GetVolumeInformation( Buf, NULL, 0, NULL, NULL,
 51         &dwSysFlags, FileSysNameBuf,
 52         FILESYSNAMEBUFSIZE);
 53
 54     if (! (dwSysFlags & FILE_SUPPORTS_REPARSE_POINTS))
 55     {
 56         printf ("\tThis file system does not support volume mount points.\n");
 57     }
 58     else
 59     {
 60         // 本卷中的挂载点
 61         hPt = FindFirstVolumeMountPoint(
 62             Buf, // 卷的跟跟踪
 63             PtBuf, // 挂载点路径
 64             BUFSIZE
 65             );
 66
 67         if (hPt == INVALID_HANDLE_VALUE)
 68         {
 69             printf ("\tNo volume mount points found!\n");
 70         }
 71         else
 72         {
 73             // 处理挂载点
 74             bFlag = ProcessVolumeMountPoint (hPt,
 75                 PtBuf,
 76                 BUFSIZE,
 77                 Buf);
 78             // 循环
 79             while (bFlag)
 80                 bFlag =
 81                 ProcessVolumeMountPoint (hPt, PtBuf, BUFSIZE, Buf);
 82             // 结束
 83             FindVolumeMountPointClose(hPt);
 84         }
 85     }
 86
 87     // 下一个
 88     bFlag = FindNextVolume(
 89         hVol, Buf, iBufSize);
 90
 91     return (bFlag);
 92 }
 93 /* ************************************
 94 * int GetMountPoint(void)
 95 * 功能 获取挂载点
 96 **************************************/
 97 int GetMountPoint(void)
 98 {
 99     TCHAR buf[BUFSIZE];   // 卷标识符
100     HANDLE hVol;      // 卷句柄
101     BOOL bFlag;      // 结果标志
102
103     printf("Volume mount points info of this computer:\n\n");
104     // 打开卷
105     hVol = FindFirstVolume (buf, BUFSIZE );
106     if (hVol == INVALID_HANDLE_VALUE)
107     {
108         printf ("No volumes found!\n");
109         return (-1);
110     }
111
112     bFlag = ProcessVolume (hVol, buf, BUFSIZE);
113     while (bFlag)
114     {
115         bFlag = ProcessVolume (hVol, buf, BUFSIZE);
116     }
117
118     bFlag = FindVolumeClose( hVol );
119     return (bFlag);
120 }
121
122 /* ************************************
123 * void Usage (PCHAR argv)
124 * 功能 使用方法
125 **************************************/
126 void Usage (PCHAR argv)
127 {
128     printf( "\n\n\t%s, mount a volume at a mount point.\n", argv );
129     printf( "\tFor example, \"mount D:\\mnt\\drives\\ E:\\\"\n" );
130 }
131
132 /* ************************************
133 * main
134 * 功能 入口函数
135 **************************************/
136 int main( int argc, PCHAR argv[] )
137 {
138     BOOL bFlag;
139     CHAR Buf[BUFSIZE];
140
141     if( argc != 3 )
142     {
143         GetMountPoint();
144         Usage( argv[0] );
145         return( -1 );
146     }
147
148     bFlag = GetVolumeNameForVolumeMountPointA(
149         argv[2],   // 输入挂载点或目录
150         Buf,     // 输出卷名
151         BUFSIZE
152         );
153
154     if (bFlag != TRUE)
155     {
156         printf( "Retrieving volume name for %s failed.\n", argv[2] );
157         return (-2);
158     }
159
160     printf( "Volume name of %s is %s\n", argv[2], Buf );
161     bFlag = SetVolumeMountPointA(
162         argv[1], // 挂载点
163         Buf    // 需要挂载的卷
164         );
165
166     if (!bFlag)
167     {
168         printf ("Attempt to mount %s at %s failed. error code is\n",
169             argv[2], argv[1], GetLastError());
170     }
171
172     return (bFlag);
173 }

http://www.cnblogs.com/zjutlitao/p/3585462.html

时间: 2024-08-10 19:04:09

[WinAPI] API 6 [操作驱动器挂载点]的相关文章

Lua中C API栈操作

向栈中压入数据: lua_pushnil(lua_State*); lua_pushboolean(lua_State*, bool); lua_pushnumber(lua_State*, lua_Number); lua_pushinteger(lua_State*, lua_Integer) lua_pushlstring(lua_State*, const char*, size_t); lua_pushstring(lua_State*, const char*); 获取栈中元素的类型

借助Sigar API获取操作系统信息

Sigar(全称System Information Gatherer And Reporter,即系统信息收集报表器),它提供了一个开源的跨平台的收集计算机硬件和操作系统信息的API(该API底层接口用C语言编写),本文将演示如何借助Sigar API获取操作系统信息: package com.ghj.packageoftest; import java.net.InetAddress; import org.hyperic.sigar.OperatingSystem; import org.

jquery api 常见api 效果操作例子

addClass_removeClass_toggleClass_hasClass.html 1 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> 2 <html> 3 <head> 4 <title>method_1.html</title> 5 <meta http-equiv="content-type" conten

jquery api 常见api 元素操作例子

append_prepend.html 1 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> 2 <html> 3 <head> 4 <title>method_1.html</title> 5 <meta http-equiv="content-type" content="text/html; charset=

InfluxDB学习之InfluxDB的HTTP API写入操作

HTTP API也有两种操作:写入和查询,本文就先给大家介绍一下 InfluxDB的HTTP API的写入操作方式. 在InfluxDB学习的上一篇文章:InfluxDB学习之InfluxDB的基本操作 中,我们提到 InfluxDB操作有三种方式,其中一种是HTTP API的方式. HTTP API也有两种操作:写入和查询,本文就先给大家介绍一下 InfluxDB的HTTP API的写入操作方式.更多InfluxDB详细教程请看:InfluxDB系列学习教程目录 InfluxDB技术交流群:5

FileSystemObject对象操作驱动器(Drives)

使用FileSystemObject对象来编程操作驱动器(Drives)和文件夹(Folders)很容易,这就像在Windows文件浏览器中对文件进行交互操作一样 比如:拷贝.移动文件夹,获取文件夹的属性. 1.Drives对象属性 Drive对象负责收集系统中的物理或逻辑驱动器资源内容,它具有如下属性: TotalSize:以字节(byte)为单位计算的驱动器大小. AvailableSpace或FreeSpace:以字节(byte)为单位计算的驱动器可用空间. DriveLetter:驱动器

用zabbix生成awstats图表以及通过Python调zabbix API自动化操作

awstats作为一款日志分析软件,功能不错,但是界面过于简单,也没有图表功能,这里我采取了一种变通的方法,将awstats的分析结果(pv.hits(文件数).bandwidth.visits(独立ip))添加到zabbix,并通过zabbix生成趋势图表. 在前两篇文章中,我们队awstats的使用及其工作方式进行了简明扼要的介绍:awstats对每个站点进行分析之后,会生成一个"awstats012016.txt"格式的"数据库"文件:awstats的展示页面

File API文件操作之FileReader

近来研究点对点的文件传输,想到一种方案FileReader+WebRtc. 当我看到FileReader的时候,哎呀,不错的东西啊,仔细一看属于File API,或者叫做Web API. File API 官方的文档  File API MDN的一些敞开 Web APIs|MDN 其主要由,FileList,Blob,File,FileReader等组成. 这里我们主要探讨一下FileReader,先看看官方网站的接口定义 [Constructor, Exposed=Window,Worker]

habse java api使用操作

上一篇cm5.4和cdh5.4安装(http://my.oschina.net/penngo/blog/517223),本文使用HBase的java客户端api操作Hbase. 需要用到的包可以在/opt/cloudera/parcels/CDH-5.4.7-1.cdh5.4.7.p0.3/jars找到,hbase版本1.0.0 HbaseTest3.java代码例子 import java.io.IOException; import org.apache.hadoop.conf.Config