CE6.0 下获得 SD 卡序列号的方法
经常在坛子里看到讨论软件加密的帖子,纯软件加密与读取硬件序列号加密是经常讨论到的。
两种方法各有优缺点。
在通过读取硬件序列号的方法来加密的方法,受硬件的限制。
一般来说,CPU和T-Flash可能存在序列号。今天研究了一下 Windows CE 6.0 下的读取 SD 卡(T-Flash)的方法,以下将自己的实现过程列出来,供有需要的朋友一起学习。
函数的声明,在.H文件文件中:
#define SD_PART_NAME L"DSK2:"
#define VALID_SD_SERIAL_1 L"A7DFB784"
BOOL GetStorageID(TCHAR *ptcCardName,TCHAR *ptcManufactureID,TCHAR *ptcSerialNum);
源代码如下函数所示:
- BOOL GetStorageID(TCHAR *ptcCardName,TCHAR *ptcManufactureID,TCHAR *ptcSerialNum)
- {
- DWORD dwSize = 0;
- DWORD dwReqSize = 0;
- STORAGE_IDENTIFICATION StoreInfo;
- STORAGE_IDENTIFICATION StoreInfo2;
- HANDLE hVolume = NULL;
- BOOL bRet = FALSE;
- BYTE *pucSerialNo = NULL;
- BYTE *pucManuID = NULL;
- int i = 0;
- ZeroMemory(&StoreInfo,sizeof(STORAGE_IDENTIFICATION));
- hVolume = CreateFile(ptcCardName,GENERIC_READ | GENERIC_WRITE,0,NULL,OPEN_EXISTING,0,NULL);
- if(NULL == hVolume || INVALID_HANDLE_VALUE == hVolume)
- {
- // MessageBox(L"Open Partation failed!");
- RETAILMSG(1,(L"Open Partation failed!\r\n"));
- return FALSE;
- }
- bRet = DeviceIoControl(hVolume,IOCTL_DISK_GET_STORAGEID,
- NULL,0,(LPVOID)&StoreInfo,/*sizeof(STORAGE_IDENTIFICATION)*/3000,&dwSize,NULL);
- if(!bRet)
- {
- DWORD dwErr = GetLastError();
- // TCHAR tcError[64];
- // wsprintf(tcError,L"Device IO 1 failed: %d!",dwErr);
- // MessageBox(tcError);
- RETAILMSG(1,(L"Device IO 1 failed: %d!\r\n",dwErr));
- CloseHandle(hVolume);
- return FALSE;
- }
- dwReqSize = StoreInfo.dwSize;
- ASSERT(dwReqSize > 0);
- dwSize = 0;
- StoreInfo2.dwSize = dwReqSize;
- bRet = DeviceIoControl(hVolume,IOCTL_DISK_GET_STORAGEID,
- NULL,0,(LPVOID)&StoreInfo,dwReqSize,&dwSize,NULL);
- if(FALSE == bRet)
- {
- DWORD dwErr = GetLastError();
- // TCHAR tcError[64];
- // wsprintf(tcError,L"Device IO 2 failed: %d!",dwErr);
- // MessageBox(tcError);
- RETAILMSG(1,(L"Device IO 2 failed: %d!\r\n",dwErr));
- CloseHandle(hVolume);
- return FALSE;
- }
- pucSerialNo = (((BYTE *)&StoreInfo) + StoreInfo.dwSerialNumOffset);
- pucManuID = (((BYTE *)&StoreInfo) + StoreInfo.dwManufactureIDOffset);
- while(pucSerialNo[i] != 0 && i < 200 && i < (int)(dwSize - StoreInfo.dwSerialNumOffset))
- {
- ptcSerialNum[i] = pucSerialNo[i];
- i++;
- }
- pucSerialNo[i] = '\0 ';
- i = 0;
- while(pucManuID[i] != 0 && i < 200 && i < (int)(StoreInfo.dwSerialNumOffset - StoreInfo.dwManufactureIDOffset))
- {
- ptcManufactureID[i] = pucManuID[i];
- i++;
- }
- pucManuID[i] = '\0 ';
- CloseHandle(hVolume);
- return TRUE;
- }
调用示例如下:
- TCHAR tcSDSerial[256];
- TCHAR tcSDManu[256];
- ZeroMemory(tcSDSerial,sizeof(TCHAR) * 256);
- ZeroMemory(tcSDManu,sizeof(TCHAR) * 256);
- if(0 == GetStorageID(SD_PART_NAME,tcSDManu,tcSDSerial))
- {
- MessageBox(tcSDSerial);
- if(0 == wcsncmp(VALID_SD_SERIAL_1,tcSDSerial,wcslen(VALID_SD_SERIAL_1)))
- {
- }
- else
- {
- }
- }
- 实现过程中,遇到以下错误:
- (1) 当将调用代码修改为: if(GetStorageID(L"DSK1:",csManufactureID,csSerialID)) 时(DSK1 是存在的)产生如下错误:
- Error 50: 不支持请求。
- (2) 当将实现代码中的 DeviceIoControl()函数 修改为如下时:
- bRet = DeviceIoControl(hVolume,IOCTL_DISK_GET_STORAGEID,
- NULL,0,(LPVOID)&StoreInfo,sizeof(STORAGE_IDENTIFICATION),&dwSize,NULL);
- 产生如下错误:Error 122: 传递给系统调用的数据区域太小。所以,建议各位程序在编码时,尽量对函数的返回值进行判断。在出错的状态,一定要调用 GetLastError() 函数获取详细的错误码。
CE6.0 下获得 SD 卡序列号的方法的更多相关文章
- Ubuntu下查看SD卡设备名的几个方法
Ubuntu下使用SD卡查询SD卡的设备文件名:sudo fdisk -leg:Disk /dev/sdb:14.9 GiB,15931539456 字节,31116288 个扇区单元:扇区 / 1 ...
- Linux的启动SD卡的格式化方法
要在OMAP3530上运行Linux,首先要知道如何启动OMAP3530,并且将MLO,XDLR,UBOOT,UImage以及文件系统等镜像程序下载到OMAP3530的芯片中去. OMAP3530提供 ...
- 【译】如何在 Android 5.0 上获取 SD卡 的读写权限
因为最近项目需要,涉及到 SD卡 的读写操作,然而申请 <!-- 读写权限 --> <uses-permission android:name="android.permi ...
- 基于stm32f103zet6的FAT16文件系统学习0(读SD卡扇区)
SD卡已经看了两天了,主要是因为测试出来的卡容量不对,所以一直找原因,最终还是发现了,总比不过是单位上面出现了问题,或许是之前没有接触到SD的缘故吧,所以对其中的一些寄存器很不了解,一切都是重新开始, ...
- Mac下给SD卡烧录树莓派系统
1.mac 磁盘工具 抹掉sd卡 为fat 2. df -h 看清sd卡号 3. 卸载sd卡 diskutil unmount /dev/disk2s2 Volume UNTITLED on disk ...
- 关于ARM Linux下的SD卡及U盘的挂载问题
内核配置并运行后,挂载SD卡,出现问题: zynq> mount -t /dev/mmcblk1 /mntmount: mounting /dev/mmcblk0 on /mnt failed: ...
- Linux环境下挂载SD卡的教程
1.插入SD卡 如果系统能够识别SD卡,则会打印一些信息: 2.查看系统给SD卡分配的设备名 命令如下: fdisk -l 命令 说明:通常是根据SD卡的存储容量来确定的. 比如下面的信息: 3.挂载 ...
- SPI模式下MCU对SD卡的控制及操作命令
一.前言 SD 卡有两个可选的通讯协议:SD 模式和 SPI模式 SD 模式是SD 卡标准的读写方式,但是在选用SD 模式时,往往需要选择带有SD 卡控制器接口的 MCU,或者必须加入额外的SD卡控制 ...
- SPI模式下MCU对SD卡的控制及操作命令(转)
源:SPI模式下MCU对SD卡的控制及操作命令 一.前言 SD 卡有两个可选的通讯协议:SD 模式和 SPI模式 SD 模式是SD 卡标准的读写方式,但是在选用SD 模式时,往往需要选择带有SD 卡控 ...
随机推荐
- APP自动化框架LazyAndroid使用手册(3)--核心API介绍
作者:黄书力 概述 在前一篇博文中,简要介绍了一款安卓UI自动化测试框架LazyAndroid (http://blog.csdn.net/kaka1121/article/details/53204 ...
- PHP学习(4)——数据类型
PHP 支持 8 种原始数据类型. 四种标量类型:(标量类型即为基本类型) boolean(布尔型) integer(整型) float(浮点型,也称作 double) (由于历史原因,float也叫 ...
- Dynamics CRM2016 Web Api之根据时间查询数据
我的博文里已经有多次提到CRM中的时间处理问题了,本篇继续探讨在web api的场景下时间字段如何处理,本篇只涉及查询,针对2016中新增的时间行为"用户当地时间"和"无 ...
- CDH 5.x 集群安装及卸载
上次写了CDH安装测试总结,由于那个博客篇幅略长, 但是主要集中在第二章,所以单独把CDH安装.卸载这块的内容拉出来在一篇记录一下. 一.搭建远程yum源 1.启动http服务: service ht ...
- RxJava(十一)defer操作符实现代码支持链式调用
欢迎转载,转载请标明出处: http://blog.csdn.net/johnny901114/article/details/52597643 本文出自:[余志强的博客] 一.前言 现在越来越多An ...
- Android N(7.0) 被美翻的新特性!
Tamic 专注移动开发!更多文章请关注 Csdn: http://blog.csdn.net/sk719887916/article/details/52612444 $ http://www.ji ...
- iter 函数另类用法
它可以很简单地构造一个无限迭代器: ): print(i) #将无限打印出0 原来,如果iter有第二个参数,那么第一个参数必须是一个参数可以省略的可调用对象.int函数符合这种要求. 迭代什么时候停 ...
- Dynamics CRM2016 Web API之通过实体的primary key查询记录(二)
继续接上篇,还是通过primary key来查询数据,本篇介绍两个我个人比较喜欢的查询方式,一个是查询单个字段,一个是查询lookup关联实体中的属性字段. 先来看如何查询单个字段,只需要在url的最 ...
- 使用C++将OpenCV中Mat的数据写入二进制文件,用Matlab读出
在使用OpenCV开发程序时,如果想查看矩阵数据,比较费劲,而matlab查看数据很方便,有一种方法,是matlab和c++混合编程,可以用matlab访问c++的内存,可惜我不会这种方式,所以我就把 ...
- webstorm工具使用详解
webstorm简单介绍 官网地址:http://www.jetbrains.com/webstorm/features/index.html 参考地址:http://www.html5jscss.c ...