一般的U盘不具备加密的功能,虽然U盘和加密狗外形有一些相似,但是内部完全不一样的,U盘只是一个存储器芯片和简单的附属电路,而现在的智能卡加密狗都具有一个单独的CPU或者加密芯片,可以执行相当复杂的加密算法。 有的软件开发商有这样一种需求,就是使用U盘发布软件的同时,想要节约成本,防止U盘中的软件被复制,但又不想再购买昂贵的加密狗,因此想要把软件绑定在U盘上执行,当U盘拔下来的时候,软件就不能正常运行,和我先前介绍的绑定硬件指纹相似,使用绑定U盘的方式加密软件。 在对软件安全不是特别在意的情况下,可以在软件中采用绑定U盘内部ID的方式来实现这种加密,先使用程序将U盘的ID读出来,然后根据这个ID生成License文件,当解密者将U盘内的文件复制到其他电脑的时候,软件执行过程中读取U盘ID失败,因此就无法校验License。 通常情况下两个U盘的ID是不相同的,因此即使将软件复制到另外一个U盘,软件执行的时候,根据U盘ID验证License,也会出现不匹配的现象,这样就实现了软件绑定U盘的加密方式。 需要指出的是,这种U盘加密并不算安全,大多数U盘厂商有内部量产工具,可以修改U盘的内部ID号码,这就存在了复制U盘的可能性,但对于普通用户来说,通常没有修改U盘内部ID的能力,因此也具有一定的加密性。 这个加密方法中,读取U盘ID号的函数的VB源代码如下所示: Set objWMIService = GetObject("winmgmts:\\.\root\cimv2")5 E! Y3 G. F8 b ^" t
Set colItems = objWMIService.ExecQuery("Select * From Win32_USBHub")# u) Z+ f- S$ W. A; }9 J3 I
For Each objItem In colItems
|6 u4 S) c+ z" ~. f5 N* ]7 O a = objItem.DeviceID0 s ^1 Z- P+ n T/ @
If InStr(a, "VID") Then b = Split(a, "\")
- D: X; n$ M% N# ?4 \& M0 E/ W USB_ID = b(UBound(b))7 n0 V, g; ~8 g% M
Next
) g7 p, s3 w K3 I$ n+ i4 J1 v
' T2 ?7 h S X2 k3 q
& \ L; j/ `: G9 y! l& F0 d; q! M; R& u4 h1 o) i* y
本文地址:http://www.williamlong.info/archives/1832.html
* D* R6 P; v4 P) O4 r3 Y# U5 C' M F; l2 W6 Z
|