有的軟體開發商有這樣一種需求,就是使用隨身碟釋出軟體的同時,想要節約成本,防止隨身碟中的軟體被複制,但又不想再購買昂貴的加密狗,因此想要把軟體繫結在隨身碟上執行,當隨身碟拔下來的時候,軟體就不能正常執行,和先前介紹的繫結硬體指紋相似,使用繫結隨身碟的方式加密軟體。
在對軟體安全不是特別在意的情況下,可以在軟體中採用繫結隨身碟內部ID的方式來實現這種加密,先使用程式將隨身碟的ID讀出來,然後根據這個ID生成License檔案,當解密者將隨身碟內的檔案複製到其他電腦的時候,軟體執行過程中讀取隨身碟ID失敗,因此就無法校驗License。
通常情況下兩個隨身碟的ID是不相同的,因此即使將軟體複製到另外一個隨身碟,軟體執行的時候,根據隨身碟ID驗證License,也會出現不匹配的現象,這樣就實現了軟體繫結隨身碟的加密方式。
需要指出的是,這種隨身碟加密並不算安全,大多數隨身碟廠商有內部量產工具,可以修改隨身碟的內部ID號碼,這就存在了複製隨身碟的可能性,但對於普通使用者來說,通常沒有修改隨身碟內部ID的能力,因此也具有一定的加密性。
這個加密方法中,讀取隨身碟ID號的函式的VB原始碼如下所示:
Se t objW MISe rvice = Ge tObject("winmg mts:.ro otcimv2")
Se t colIte ms = objWMISer vice.E xecQ uery("Select * Fro m Wi n32_US BHub")
F or Ea ch objIte m In colI tems
a = o bjItem.De viceID
If In Str(a, "VI D") The n b = Sp lit(a, "")
US B_ID = b(UBound(b))
Ne xt