×

php获取逻辑驱动器

php获取逻辑驱动器(php获取服务器ip地址)

admin admin 发表于2023-03-29 18:42:07 浏览64 评论0

抢沙发发表评论

本文目录一览:

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获取逻辑驱动器