禁用设备
作者 佚名技术
来源 程序设计
浏览
发布时间 2012-06-29
} LPTSTR lpszMsg = NULL; try { TCHAR * GUIDString = NULL; GUID guid; ZeroMemory(&guid, sizeof(GUID)); switch(nIndex) { case 0: // 0 代表软驱 GUIDString = _T("4D36E980-E325-11CE-BFC1- 08002BE10318"); UuidFromString((unsigned char *)GUIDString, &guid); break; case 1: // 1 代表光驱 GUIDString = _T("4D36E965-E325-11CE-BFC1- 08002BE10318"); UuidFromString((unsigned char *)GUIDString, &guid); break; case 2: // 2 代表USB GUIDString = _T("36FC9E60-C465-11CF-8056- 444553540000"); UuidFromString((unsigned char *)GUIDString, &guid); break; default:; } hDevInfo = SetupDiGetClassDevs (&guid,NULL,NULL,DIGCF_PRESENT); if (INVALID_HANDLE_VALUE == hDevInfo) { FormatMSG(GetLastError(), &lpszMsg); throw lpszMsg; } DWORD i; SP_DEVINFO_DATA DeviceInfoData; ZeroMemory(&DeviceInfoData, sizeof(SP_DEVINFO_DATA)); DeviceInfoData.cbSize = sizeof(SP_DEVINFO_DATA); for (i = 0; SetupDiEnumDeviceInfo(hDevInfo, i, &DeviceInfoData); ++i) { if (1 == nStatus) { StateChange(DICS_ENABLE, i, hDevInfo); } else if (0 == nStatus) { StateChange(DICS_DISABLE, i, hDevInfo); } } // 释放 device information set return SetupDiDestroyDeviceInfoList(hDevInfo); } catch (TCHAR * pszError) { ::MessageBox(NULL,pszError,_T("提示"),MB_OK); if (NULL != lpszMsg) { LocalFree((HLOCAL)lpszMsg); } return FALSE; } return FALSE; } 经测试这样对光驱,软驱和USB实现禁用没有问题,但是当禁用过之后如果要 对USB实现启用必须两次调用ControlDisk(1, 2);这个函数才可,其余的两个启用 没什么问题。还有要说的就是我不是用的枚举所有的设备,然后再过滤(网上的 那个禁用网卡的就是这种方法)。 据我观察,在注册表的此项下下: HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Class\ 有很多GUID,每个GUID代表一个设备,譬如这个是USB的
这个是CDROM的
|
凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |
你可能对下面的文章感兴趣
上一篇: c++ win32 API实现方块联机游戏历程下一篇: 图形模式下的汉字显示
关于禁用设备的所有评论