经常在坛子里看到讨论软件加密的帖子,纯软件加密与读取硬件序列号加密是经常讨论到的。

两种方法各有优缺点。

在通过读取硬件序列号的方法来加密的方法,受硬件的限制。

一般来说,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);

源代码如下函数所示:

  1. BOOL GetStorageID(TCHAR *ptcCardName,TCHAR *ptcManufactureID,TCHAR *ptcSerialNum)
  2. {
  3. DWORD dwSize = 0;
  4. DWORD dwReqSize = 0;
  5. STORAGE_IDENTIFICATION StoreInfo;
  6. STORAGE_IDENTIFICATION StoreInfo2;
  7. HANDLE hVolume = NULL;
  8. BOOL bRet = FALSE;
  9. BYTE *pucSerialNo = NULL;
  10. BYTE *pucManuID = NULL;
  11. int i = 0;
  12. ZeroMemory(&StoreInfo,sizeof(STORAGE_IDENTIFICATION));
  13. hVolume = CreateFile(ptcCardName,GENERIC_READ | GENERIC_WRITE,0,NULL,OPEN_EXISTING,0,NULL);
  14. if(NULL == hVolume || INVALID_HANDLE_VALUE == hVolume)
  15. {
  16. // MessageBox(L"Open Partation failed!");
  17. RETAILMSG(1,(L"Open Partation failed!\r\n"));
  18. return FALSE;
  19. }
  20. bRet = DeviceIoControl(hVolume,IOCTL_DISK_GET_STORAGEID,
  21. NULL,0,(LPVOID)&StoreInfo,/*sizeof(STORAGE_IDENTIFICATION)*/3000,&dwSize,NULL);
  22. if(!bRet)
  23. {
  24. DWORD dwErr = GetLastError();
  25. // TCHAR tcError[64];
  26. // wsprintf(tcError,L"Device IO 1 failed: %d!",dwErr);
  27. // MessageBox(tcError);
  28. RETAILMSG(1,(L"Device IO 1 failed: %d!\r\n",dwErr));
  29. CloseHandle(hVolume);
  30. return FALSE;
  31. }
  32. dwReqSize = StoreInfo.dwSize;
  33. ASSERT(dwReqSize > 0);
  34. dwSize = 0;
  35. StoreInfo2.dwSize = dwReqSize;
  36. bRet = DeviceIoControl(hVolume,IOCTL_DISK_GET_STORAGEID,
  37. NULL,0,(LPVOID)&StoreInfo,dwReqSize,&dwSize,NULL);
  38. if(FALSE == bRet)
  39. {
  40. DWORD dwErr = GetLastError();
  41. // TCHAR tcError[64];
  42. // wsprintf(tcError,L"Device IO 2 failed: %d!",dwErr);
  43. // MessageBox(tcError);
  44. RETAILMSG(1,(L"Device IO 2 failed: %d!\r\n",dwErr));
  45. CloseHandle(hVolume);
  46. return FALSE;
  47. }
  48. pucSerialNo = (((BYTE *)&StoreInfo) + StoreInfo.dwSerialNumOffset);
  49. pucManuID = (((BYTE *)&StoreInfo) + StoreInfo.dwManufactureIDOffset);
  50. while(pucSerialNo[i] != 0 && i < 200 && i < (int)(dwSize - StoreInfo.dwSerialNumOffset))
  51. {
  52. ptcSerialNum[i] = pucSerialNo[i];
  53. i++;
  54. }
  55. pucSerialNo[i] = '\0 ';
  56. i = 0;
  57. while(pucManuID[i] != 0 && i < 200 && i < (int)(StoreInfo.dwSerialNumOffset - StoreInfo.dwManufactureIDOffset))
  58. {
  59. ptcManufactureID[i] = pucManuID[i];
  60. i++;
  61. }
  62. pucManuID[i] = '\0 ';
  63. CloseHandle(hVolume);
  64. return TRUE;
  65. }

调用示例如下:

  1. TCHAR tcSDSerial[256];
  2. TCHAR tcSDManu[256];
  3. ZeroMemory(tcSDSerial,sizeof(TCHAR) * 256);
  4. ZeroMemory(tcSDManu,sizeof(TCHAR) * 256);
  5. if(0 == GetStorageID(SD_PART_NAME,tcSDManu,tcSDSerial))
  6. {
  7. MessageBox(tcSDSerial);
  8. if(0 == wcsncmp(VALID_SD_SERIAL_1,tcSDSerial,wcslen(VALID_SD_SERIAL_1)))
  9. {
  10. }
  11. else
  12. {
  13. }
  14. }
  15. 实现过程中,遇到以下错误:
  16. (1) 当将调用代码修改为: if(GetStorageID(L"DSK1:",csManufactureID,csSerialID)) 时(DSK1 是存在的)产生如下错误:
  17. Error 50: 不支持请求。
  18. (2) 当将实现代码中的 DeviceIoControl()函数 修改为如下时:
  19. bRet = DeviceIoControl(hVolume,IOCTL_DISK_GET_STORAGEID,
  20. NULL,0,(LPVOID)&StoreInfo,sizeof(STORAGE_IDENTIFICATION),&dwSize,NULL);
  21. 产生如下错误:Error 122: 传递给系统调用的数据区域太小。所以,建议各位程序在编码时,尽量对函数的返回值进行判断。在出错的状态,一定要调用 GetLastError() 函数获取详细的错误码。

CE6.0 下获得 SD 卡序列号的方法的更多相关文章

  1. Ubuntu下查看SD卡设备名的几个方法

    Ubuntu下使用SD卡查询SD卡的设备文件名:sudo fdisk -leg:Disk /dev/sdb:14.9 GiB,15931539456 字节,31116288 个扇区单元:扇区 / 1 ...

  2. Linux的启动SD卡的格式化方法

    要在OMAP3530上运行Linux,首先要知道如何启动OMAP3530,并且将MLO,XDLR,UBOOT,UImage以及文件系统等镜像程序下载到OMAP3530的芯片中去. OMAP3530提供 ...

  3. 【译】如何在 Android 5.0 上获取 SD卡 的读写权限

    因为最近项目需要,涉及到 SD卡 的读写操作,然而申请 <!-- 读写权限 --> <uses-permission android:name="android.permi ...

  4. 基于stm32f103zet6的FAT16文件系统学习0(读SD卡扇区)

    SD卡已经看了两天了,主要是因为测试出来的卡容量不对,所以一直找原因,最终还是发现了,总比不过是单位上面出现了问题,或许是之前没有接触到SD的缘故吧,所以对其中的一些寄存器很不了解,一切都是重新开始, ...

  5. Mac下给SD卡烧录树莓派系统

    1.mac 磁盘工具 抹掉sd卡 为fat 2. df -h 看清sd卡号 3. 卸载sd卡 diskutil unmount /dev/disk2s2 Volume UNTITLED on disk ...

  6. 关于ARM Linux下的SD卡及U盘的挂载问题

    内核配置并运行后,挂载SD卡,出现问题: zynq> mount -t /dev/mmcblk1 /mntmount: mounting /dev/mmcblk0 on /mnt failed: ...

  7. Linux环境下挂载SD卡的教程

    1.插入SD卡 如果系统能够识别SD卡,则会打印一些信息: 2.查看系统给SD卡分配的设备名 命令如下: fdisk -l 命令 说明:通常是根据SD卡的存储容量来确定的. 比如下面的信息: 3.挂载 ...

  8. SPI模式下MCU对SD卡的控制及操作命令

    一.前言 SD 卡有两个可选的通讯协议:SD 模式和 SPI模式 SD 模式是SD 卡标准的读写方式,但是在选用SD 模式时,往往需要选择带有SD 卡控制器接口的 MCU,或者必须加入额外的SD卡控制 ...

  9. SPI模式下MCU对SD卡的控制及操作命令(转)

    源:SPI模式下MCU对SD卡的控制及操作命令 一.前言 SD 卡有两个可选的通讯协议:SD 模式和 SPI模式 SD 模式是SD 卡标准的读写方式,但是在选用SD 模式时,往往需要选择带有SD 卡控 ...

随机推荐

  1. Linux块设备加密之dm-crypt分析

    相关的分析工作一年前就做完了,一直懒得写下来.现在觉得还是写下来,以来怕自己忘记了,二来可以给大家分享一下自己的研究经验. 这篇文章算是<Device Mapper代码分析>的后续篇,因为 ...

  2. 初识Spark2.0之Spark SQL

    内存计算平台spark在今年6月份的时候正式发布了spark2.0,相比上一版本的spark1.6版本,在内存优化,数据组织,流计算等方面都做出了较大的改变,同时更加注重基于DataFrame数据组织 ...

  3. Cocos2D-ObjC:在RPG游戏中混合Swift代码

    我之前写过一个RPG游戏<<熊猫之魂 SoulOfPanda>> 编译器使用的是SpriteBuilder,很好很强大!全部代码都由Objc完成,现在想尝试一下在其中混入Swi ...

  4. SpringMVC源码分析--文件上传

    SpringMVC提供了文件上传的功能,接下来我们就简单了解一下SpringMVC文件上传的开发及大致过程. 首先需要在springMVC的配置文件中配置文件上传解析器 <bean id=&qu ...

  5. java详解final、多态、抽象类、接口原理

    1:final关键字(掌握) (1)是最终的意思,可以修饰类,方法,变量. (2)特点: A:它修饰的类,不能被继承. B:它修饰的方法,不能被重写. C:它修饰的变量,是一个常量. (3)面试相关: ...

  6. Dynamics CRM 非声明验证方式下连接组织服务的两种方式的性能测试

    今天看了勇哥的博文"http://luoyong0201.blog.163.com/blog/static/1129305201510153391392/",又认识到了一种新的连接 ...

  7. java虚拟机 jvm 方法区实战

    和java堆一样,方法区是一块所有线程共享的内存区域,用于保存系统的类信息,类的信息有哪些呢.字段.方法.常量池.方法区也有一块内存区域所以方法区的内存大小,决定了系统可以包含多少个类,如果系统类太多 ...

  8. Android 优质精准的用户行为统计和日志打捞方案

    Android 自定义优质精准的用户行为和日志打捞方案 Tamic csdn博客 :http://blog.csdn.net/sk719887916/article/details/51398416 ...

  9. Android 震动马达系统

    Android之 看"马达"如何贯通Android系统 (从硬件设计 --> 驱动 --> HAL --> JNI --> Framework --> ...

  10. Dubbo粗浅记录

    这篇博客只是我自己的学习记录,对各位高手怕是没有什么太大的帮助,望高手不吝赐教. 项目的截图如下: 我们使用的主要就是红框里面的. 这里我主要分析两个xml /DubboTest/src/main/r ...