如何利用隨身碟給軟體加密

把我給崩了發表於2016-07-04

  有的軟體開發商有這樣一種需求,就是使用隨身碟釋出軟體的同時,想要節約成本,防止隨身碟中的軟體被複制,但又不想再購買昂貴的加密狗,因此想要把軟體繫結在隨身碟上執行,當隨身碟拔下來的時候,軟體就不能正常執行,和先前介紹的繫結硬體指紋相似,使用繫結隨身碟的方式加密軟體。

  在對軟體安全不是特別在意的情況下,可以在軟體中採用繫結隨身碟內部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

相關文章