本文目录一览:
G盘光驱无法访问,显示拒绝访问 光驱是好的?
1、在控制台树中,单击"逻辑驱动器"。
位置
计算机管理(本地)
存储
逻辑驱动器
2、右键单击需要设置访问权限的驱动器,单击"属性",然后单击"安全"选项卡。
3、执行下列的一项操作:
要为新用户或组设置访问权限,请单击"添加"。在"搜索范围"中,选择该用户或组是其成员的域。在"名称"中,键入需要设置权限的用户或组的名称,单击"添加",然后单击"确定"以关闭该对话框。
要从权限列表中删除现有用户或组,请单击用户或组的名称,单击"删除",然后单击"确定"。
4、在"权限"中为每个要允许或拒绝的访问权限单击"允许"或"拒绝"。
注意
必须以管理员或管理组成员的身份登录才能完成该过程。如果计算机与网络连接,则网络策略设置也可能阻止您完成此步骤。
只能在格式化为 NTFS 的驱动器上更改访问权限。
无论访问权限如何保护驱动器上的个别文件和文件夹,被授予对驱动器"完全控制"权限的用户和组可以删除该驱动器上的文件和文件夹。
逻辑驱动器只允许在驱动器的根目录上设置权限。但是,它支持权限继承,所以根目录下的文件夹和文件可以继承所设置的权限。
可以更改远程计算机或本地计算机上的访问权限。要访问远程计算机,请用右键单击"计算机管理(本地)",单击"连接到另一台计算机",然后选择需要连接的计算机。
4.2 使用FindFirstVolume系列函数遍历驱动器信息
效果
和上一个方法区别在于如红框处,驱动名返回的是以\\?\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;
}
逻辑驱动器是什么?
1、逻辑驱动器是在基本主启动记录
(MBR)
磁盘的扩展磁盘分区中创建的卷。逻辑驱动器类似于主磁盘分区,只是每个磁盘最多只能有四个主磁盘分区,而在每个磁盘上创建的逻辑驱动器的数目不受限制。逻辑驱动器可以被格式化并指派驱动器号。
2、逻辑驱动器一般是称呼硬盘的若干个分区。新硬盘开始使用前,必须对其进行分区。为了更好地利用硬盘空间,通常将其整体空间分成若干个区域,在操作系统上看硬盘,比如说Windows的“我的电脑”中,看到有“本地磁盘(C)”、“本地磁盘(D)”、“本地磁盘(E)”等,看起来好像有多个硬盘(多个物理驱动器也会表现为上述的形式),其实在逻辑上它们是在一块硬盘上的,这些硬盘分区,称之为逻辑驱动器。-php获取逻辑驱动器