文章詳情頁(yè)
運(yùn)用加密技術(shù)保護(hù)Java源代碼(4)
瀏覽:63日期:2024-06-29 16:17:00
內(nèi)容: if (clasz != null)return clasz;// 下面是定制部分try {// 讀取經(jīng)過(guò)加密的類文件byte classData[] = Util.readFile( name+'.class' );if (classData != null) {// 解密...byte decryptedClassData[] = cipher.doFinal( classData );// ... 再把它轉(zhuǎn)換成一個(gè)類clasz = defineClass( name, decryptedClassData,0, decryptedClassData.length );System.err.println( '[DecryptStart: decrypting class '+name+']' );}} catch( FileNotFoundException fnfe ) {}// 必需的步驟2:如果上面沒(méi)有成功// 我們嘗試用默認(rèn)的ClassLoader裝入它if (clasz == null)clasz = findSystemClass( name );// 必需的步驟3:如有必要,則裝入相關(guān)的類if (resolve && clasz != null)resolveClass( clasz );// 把類返回給調(diào)用者return clasz;} catch( IOException ie ) {throw new ClassNotFoundException( ie.toString());} catch( GeneralSecurityException gse ) {throw new ClassNotFoundException( gse.toString());}}}對(duì)于未經(jīng)加密的應(yīng)用,正常執(zhí)行方式如下: % java App arg0 arg1 arg2對(duì)于經(jīng)過(guò)加密的應(yīng)用,則相應(yīng)的運(yùn)行方式為:% java DecryptStart key.data App arg0 arg1 arg2DecryptStart有兩個(gè)目的。一個(gè)DecryptStart的實(shí)例就是一個(gè)實(shí)施即時(shí)解密操作的定制ClassLoader;同時(shí),DecryptStart還包含一個(gè)main過(guò)程,它創(chuàng)建解密器實(shí)例并用它裝入和運(yùn)行應(yīng)用。示例應(yīng)用App的代碼包含在App.java、Foo.java和Bar.java內(nèi)。Util.java是一個(gè)文件I/O工具,本文示例多處用到了它。完整的代碼請(qǐng)從本文最后下載。五、注意事項(xiàng) 我們看到,要在不修改源代碼的情況下加密一個(gè)Java應(yīng)用是很容易的。不過(guò),世上沒(méi)有完全安全的系統(tǒng)。本文的加密方式提供了一定程度的源代碼保護(hù),但對(duì)某些攻擊來(lái)說(shuō)它是脆弱的。 雖然應(yīng)用本身經(jīng)過(guò)了加密,但啟動(dòng)程序DecryptStart沒(méi)有加密。攻擊者可以反編譯啟動(dòng)程序并修改它,把解密后的類文件保存到磁盤。降低這種風(fēng)險(xiǎn)的辦法之一是對(duì)啟動(dòng)程序進(jìn)行高質(zhì)量的模糊處理。或者,啟動(dòng)程序也可以采用直接編譯成機(jī)器語(yǔ)言的代碼,使得啟動(dòng)程序具有傳統(tǒng)執(zhí)行文件格式的安全性。 另外還要記住的是,大多數(shù)JVM本身并不安全。狡猾的黑客可能會(huì)修改JVM,從ClassLoader之外獲取解密后的代碼并保存到磁盤,從而繞過(guò)本文的加密技術(shù)。Java沒(méi)有為此提供真正有效的補(bǔ)救措施。 不過(guò)應(yīng)該指出的是,所有這些可能的攻擊都有一個(gè)前提,這就是攻擊者可以得到密匙。如果沒(méi)有密匙,應(yīng)用的安全性就完全取決于加密算法的安全性。雖然這種保護(hù)代碼的方法稱不上十全十美,但它仍不失為一種保護(hù)知識(shí)產(chǎn)權(quán)和敏感用戶數(shù)據(jù)的有效方案。 參考資源 在運(yùn)行時(shí)刻更新功能模塊。介紹了一個(gè)利用類庫(kù)加載器ClassLoader 實(shí)現(xiàn)在運(yùn)行時(shí)刻更新部分功能模塊的Java程序,并將其與C/C++中實(shí)現(xiàn)同樣功能的動(dòng)態(tài)鏈接庫(kù)方案進(jìn)行了比較。 Java 技巧 105:利用 JWhich 掌握類路徑。展示一個(gè)簡(jiǎn)單的工具,它可以清楚地確定類裝載器從類路徑中載入了什么 Java 類。 要了解更多的 Java 安全信息,請(qǐng)閱讀 java.sun.com的 Java Security API 頁(yè)。 如何封鎖您的(或打開(kāi)別人的) Java 代碼。Java 代碼反編譯和模糊處理的指南。 使您的軟件運(yùn)行起來(lái):擺弄數(shù)字。真正安全的軟件需要精確的隨機(jī)數(shù)生成器。 下載本文代碼:EncryptedJavaClass_code.zip關(guān)于作者 俞良松,軟件工程師,獨(dú)立顧問(wèn)和自由撰稿人。最初從事PB和Oracle開(kāi)發(fā),現(xiàn)主要興趣在于Internet開(kāi)發(fā)。您可以通過(guò) javaman@163.net 和我聯(lián)系。 Java, java, J2SE, j2se, J2EE, j2ee, J2ME, j2me, ejb, ejb3, JBOSS, jboss, spring, hibernate, jdo, struts, webwork, ajax, AJAX, mysql, MySQL, Oracle, Weblogic, Websphere, scjp, scjd
標(biāo)簽:
Java
相關(guān)文章:
1. Python實(shí)現(xiàn)常見(jiàn)的幾種加密算法(MD5,SHA-1,HMAC,DES/AES,RSA和ECC)2. 深入Java字節(jié)碼加密3. Springboot Druid 自定義加密數(shù)據(jù)庫(kù)密碼的幾種方案4. Python實(shí)現(xiàn)AES加密,解密的兩種方法5. python實(shí)現(xiàn)希爾密碼加密的示例代碼6. PHP基于openssl實(shí)現(xiàn)非對(duì)稱加密代碼實(shí)例7. JAVA上加密算法的實(shí)現(xiàn)用例8. JavaScript中高階函數(shù)的巧妙運(yùn)用9. .NET API 接口數(shù)據(jù)傳輸加密最佳實(shí)踐記錄10. jsp中javaBean的運(yùn)用
排行榜
