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

两种方法各有优缺点。

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

一般来说,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. Android系统对话框——自定义关闭

    Android系统对话框--自定义关闭 Dialog是我们在项目中经常用到的,5.x以后的Dialog也很好看,很安卓风,Android也给我们提供了新的包,低版本可以显示一样的效果.我们在使用的导入 ...

  2. Android的5层平台架构

    Android 是一种基于 Linux 的开放源代码软件栈,为广泛的设备和机型而创建.下图所示为 Android 平台的主要组件. Android 软件栈 Linux 内核 Android 平台的基础 ...

  3. Retrofit,Okhttp对每个Request统一动态添加header和参数(五)

    文/Tamic 地址:http://blog.csdn.net/sk719887916/article/details/52189602 Header How to Add header to Eve ...

  4. NuGet包断线续传下载

    NuGet包断线续传下载(金庆的专栏)NuGet是VC的扩展,用来下载依赖包.NuGet下载没有断线续传,下载源又很容易断开.  https://nuget.org/api/v2/  https:// ...

  5. ORACLE异常(整理网上资料)

    一.oracle预定义异常 命名的系统异常 产生原因 Oracle Error SQLCODE Value ACCESS_INTO_NULL 未定义对象 ORA-06530  -6530 CASE_N ...

  6. 【SSH系列】---Hibernate的基本映射

    开篇前言       在前面的博文中,小编分别介绍了[SSH系列]-- hibernate基本原理&&入门demo,通过这篇博文,小伙伴们对hibernate已经有了基本的了解,以及h ...

  7. [error]error while loading shared libraries: libpcre.so.1 解决

    nginx 安装好之后,启动的时候报错 [root@localhost nginx-1.6.2]# /usr/local/nginx/sbin/nginx  /usr/local/nginx/sbin ...

  8. 安卓开发过程中空指针的问题Java.lang.NullPointerException

    最近做一个新闻客户端的应用,经常出现空指针的问题,我想一方面可能是自己水平有限,二是开发过程中有一些遗漏的地方.一般情况下新手出现空指针的概率较高.下面来总结一下经常出现的问题. 1.所谓的指针,就是 ...

  9. (一二三)基于GCD的dispatch_once实现单例设计

    要实现单例,关键是要保证类的alloc和init只被调用一次,并且被自身强引用防止释放. 近日读唐巧先生的<iOS开发进阶>,受益匪浅,通过GCD实现单例就是收获之一,下面把这个方法与大家 ...

  10. 【移动开发】自定义ProgressBar

    <ProgressBar android:layout_centerInParent="true" android:layout_width="30dp" ...