在VC中如何获得USB设备的Product ID,Vendor ID等信息

void   CGetUDiskDriverDlg::SearchUDISK()  
{  
int   nCount,   len;//标记同一设备个数  
HDEVINFO   hDevInfoSet;  
BOOL   bResult;  
char   *   devicename;  
char   volume[MAX_PATH];  
char   ch[100];  

memset(volume,   0,   MAX_PATH);  

PSP_DEVICE_INTERFACE_DETAIL_DATA   pDetail   =NULL;  

//   取得一个该GUID相关的设备信息集句柄  
hDevInfoSet   =   ::SetupDiGetClassDevs((LPGUID)&HARDDISK_GUID,//GUID_CLASS_USB_DEVICE,   //   class   GUID  
NULL,   //   无关键字  
NULL,   //   不指定父窗口句柄  
DIGCF_PRESENT   ¦   DIGCF_DEVICEINTERFACE);   //   目前存在的设备  

//   失败...  
if   (hDevInfoSet   ==   INVALID_HANDLE_VALUE)  
{  
return;  
}  

//   申请设备接口数据空间  

nCount   =   0;  
bResult   =   TRUE;  

SP_DEVICE_INTERFACE_DATA   ifdata;  
//   设备序号=0,1,2...   逐一测试设备接口,到失败为止  
while   (bResult)  
{  

ifdata.cbSize   =   sizeof(ifdata);  
//   枚举符合该GUID的设备接口  
bResult   =   ::SetupDiEnumDeviceInterfaces(  
hDevInfoSet,   //   设备信息集句柄  
NULL,   //   不需额外的设备描述  
(LPGUID)&HARDDISK_GUID,//GUID_CLASS_USB_DEVICE,   //   GUID  
(ULONG)nCount,   //   设备信息集里的设备序号  
&ifdata);   //   设备接口信息  

if   (bResult)  
{  
ULONG   predictedLength   =   0;  
ULONG   requiredLength   =   0;  
//   取得该设备接口的细节(设备路径)  
bResult   =   SetupDiGetInterfaceDeviceDetail(  
hDevInfoSet,   //   设备信息集句柄  
&ifdata,   //   设备接口信息  
NULL,   //   设备接口细节(设备路径)  
0,   //   输出缓冲区大小  
&requiredLength,   //   不需计算输出缓冲区大小(直接用设定值)  
NULL);   //   不需额外的设备描述  
//   取得该设备接口的细节(设备路径)  
predictedLength=requiredLength;  

//   if(pDetail)  
//   {  
//   pDetail   =NULL;  
//   }  
pDetail   =   (PSP_INTERFACE_DEVICE_DETAIL_DATA)::GlobalAlloc(LMEM_ZEROINIT,   predictedLength);  
pDetail- >cbSize   =   sizeof(SP_DEVICE_INTERFACE_DETAIL_DATA);  
bResult   =   SetupDiGetInterfaceDeviceDetail(  
hDevInfoSet,   //   设备信息集句柄  
&ifdata,   //   设备接口信息  
pDetail,   //   设备接口细节(设备路径)  
predictedLength,   //   输出缓冲区大小  
&requiredLength,   //   不需计算输出缓冲区大小(直接用设定值)  
NULL);   //   不需额外的设备描述  

if   (bResult)  
{  
//   复制设备路径到输出缓冲区  
for(int   i=0;i <17;i++){  
ch[i]=*(pDetail- >DevicePath+8+i);  
}  
ch[17]= "/0 ";  
if   (strcmp(ch,"vid_11dd&pid_0101")==0   ¦ ¦  
strcmp(ch,"vid_11dd&pid_11dd")==0   ¦ ¦  
strcmp(ch,"vid_0101&pid_0101")==0   ¦ ¦  
strcmp(ch,"vid_0101&pid_11dd")==0)   //比较版本号,防止意外出错  
{  
len   =   strlen(pDetail- >DevicePath);  
devicename   =   new   char[len];  
memset(devicename,   0,   len);  
for(int   i=0;i <(len-38);i++)  
{  
ch[i]=*(pDetail- >DevicePath+i);  
}  
ch[len-38]= "/0 ";  
memset(volume,   0,   MAX_PATH);  
}  
}  
}  
nCount++;  
}  
//   释放设备接口数据空间  
::GlobalFree(pDetail);  

//   关闭设备信息集句柄  
::SetupDiDestroyDeviceInfoList(hDevInfoSet);  
}


本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/bengold1979/archive/2007/09/29/1805975.aspx

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
现在USB设备却很多,因此对USB设备的查找与读写就必不可少了。但是能找到关于USB读写的资料很少。这里使用VC++示范了一些获得USB信息的方法。 一、枚举USB设备   通过枚举USB控制器->枚举此控制器上的USB HUB->枚举HUB的各个端口->获得设备信息。 枚举控制器: wsprintf(HCName, "\\\\.\\HCD%d", HCNum); hHCDev = CreateFile(HCName, GENERIC_WRITE, FILE_SHARE_WRITE, NULL, OPEN_EXISTING, 0, NULL);   计算机上的USB主控制器以HCD1,HCD2等命名。通过控制器名称,使用CCreateFile 打开它。使用DeviceIoControl即可得到其驱动程序名,以及与它连接的HUB的名称。用CCreateFile打开HUB,获得连接信息。再枚举HUB的各个端口即可获得连接的设备信息。 二、枚举HID设备   HID设备是微软定义的标准人机接口规范。比如USB鼠标,USB游戏手柄等。不用查找具体设备的GUID,使用API HidD_GetHidGuid(&guidHID)即可得到GUID。有了GUID通过API SetupDiEnumDeviceInterfaces可获得是否有设备连接。如果此类设备连接通过SetupDiGetDeviceInterfaceDetail获得它的设备路径信息。使用CCreateFile 打开它,通过HidD_GetAttributes获得其基本属性信息。使用DeviceIoControl可以获得更详细的属性。在本代码如果计算机上插有USB游戏手柄,可获得信息。但不知道为什么xp下却不能获得USB鼠标的信息。 三 枚举U盘   先用GetDriveType API获得设备的类型,若类型为REMOVABLE(当然有些大容量U盘可能报告为FIXED,那就需要其他方法来确定了),即可能是U盘。用CCreateFile 打开之后,再用IOCTL_STORAGE_QUERY_PROPERTY为参数的DeviceIoControl来获得其属性。 四、结束语   示例工程在winxp+xpDDK+VC6下编译通过。USB设备种类比较多,也比较特殊,不同厂商的硬件不同,控制软件也不尽相同(我想主要是ICTL码不同,也不容易查到)。使得访问USB口的设备不象串口并口那么方便。这个例程只是展示了访问的基本方法。其还有些问题还没有解决,发出来希望大家解决之后能通知我或者发表出来。 参考了USBPort,USBview等代码,一并致谢。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值