java防反編譯 net C#開發(fā)的軟件,用什么方法防止反編譯?
net C#開發(fā)的軟件,用什么方法防止反編譯?. net是一種中間語言。當(dāng)它剛問世時,混亂更受歡迎,這使得破解者更難破解。但是,因為程序代碼是由。Net直接交給托管程序進(jìn)行解析,這對您混淆沒有多大意義
net C#開發(fā)的軟件,用什么方法防止反編譯?
. net是一種中間語言。當(dāng)它剛問世時,混亂更受歡迎,這使得破解者更難破解。但是,因為程序代碼是由。Net直接交給托管程序進(jìn)行解析,這對您混淆沒有多大意義。不管您造成多大的混亂,托管程序必須能夠識別您最終執(zhí)行它的時間。目前流行的方法是在托管程序中添加重要代碼,加密算法相結(jié)合,主代碼在多個虛擬機(jī)中執(zhí)行,或者主代碼放在服務(wù)器上。只有在注冊和解密成功后,才會返回正確的代碼。注意注冊機(jī)制,不要只驗證注冊碼是否正確。最好將注冊碼與加密算法相關(guān)聯(lián)。這樣,即使破解程序爆了你的程序,因為它無法解密主數(shù)據(jù),也沒有成功破解。
如何防止JAVA程序源代碼被反編譯?
有很多方法可以防止Java開發(fā)的程序被其他人反編譯。這里有幾種方法向您介紹它們:
1。隔離Java程序
最簡單的方法就是讓用戶無法訪問Java類程序。這種方法是最基本的方法,實現(xiàn)它的方法很多。例如,開發(fā)人員可以將密鑰Java類放在服務(wù)器端,客戶端可以訪問服務(wù)器的相關(guān)接口來獲取服務(wù),而不是直接訪問類文件。這樣,黑客就沒有辦法反編譯類文件。目前,有越來越多的標(biāo)準(zhǔn)和協(xié)議通過接口提供服務(wù),如HTTP、webservice、RPC等,但也有很多應(yīng)用不適合這種保護(hù),例如單機(jī)程序不能隔離Java程序。
2. 加密類文件
為了防止類文件被直接反編譯,許多開發(fā)人員對一些關(guān)鍵類文件進(jìn)行加密,例如與注冊碼和序列號管理相關(guān)的類。在使用這些加密的類之前,程序需要先解密它們,然后將它們加載到JVM中。這些類可以通過硬件或軟件進(jìn)行解密。
3. 將程序轉(zhuǎn)換為本機(jī)代碼也是防止反編譯的有效方法。因為本地代碼通常很難反編譯。開發(fā)人員可以選擇將整個應(yīng)用程序轉(zhuǎn)換為本地代碼或關(guān)鍵模塊轉(zhuǎn)換。如果只轉(zhuǎn)換了一些關(guān)鍵模塊,Java程序在使用這些模塊時需要使用JNI技術(shù)來調(diào)用它們。
4. 代碼混淆
代碼混淆是重新組織和處理類文件,使處理后的代碼執(zhí)行與預(yù)處理代碼相同的函數(shù)(語義)。但是混亂的代碼很難反編譯,即反編譯后的代碼很難理解和模糊,反編譯器很難得到程序的真正語義。理論上,如果黑客有足夠的時間,混亂的代碼仍然可能被破解。甚至現(xiàn)在有些人還在開發(fā)反混淆工具。但從實際情況來看,由于混淆技術(shù)的多樣化發(fā)展和混淆理論的成熟,混淆后的java代碼仍然可以防止反編譯。
比較不同的保護(hù)技術(shù),希望能給大家一個參考:
class怎么防止被反編譯?
任何加密都是沒用的,只要Java程序可以在本地運(yùn)行,一定有反編譯的方法。因為Java最終總是要編寫字節(jié)碼。如果實現(xiàn)classloader或hack JVM,就可以獲得字節(jié)碼并對其進(jìn)行反編譯。但是,由于沒有可讀性,混亂的代碼被反編譯了。。