回覆列表
  • 1 # MFing780

    防止Java開發出來的程式被別人反編譯有很多種方法,下面給你介紹幾種:

    1、隔離Java程式

    最簡單的方法就是讓使用者不能夠訪問到Java Class程式,這種方法是最根本的方法,具體實現有多種方式。例如,開發人員可以將關鍵的Java Class放在伺服器端,客戶端透過訪問伺服器的相關介面來獲得服務,而不是直接訪問Class檔案。這樣駭客就沒有辦法反編譯Class檔案。目前,透過介面提供服務的標準和協議也越來越多,例如 HTTP、Web Service、RPC等。但是有很多應用都不適合這種保護方式,例如對於單機執行的程式就無法隔離Java程式。

    2、對Class檔案進行加密

    為了防止Class檔案被直接反編譯,許多開發人員將一些關鍵的Class檔案進行加密,例如對註冊碼、序列號管理相關的類等。在使用這些被加密的類之前,程式首先需要對這些類進行解密,而後再將這些類裝載到JVM當中。這些類的解密可以由硬體完成,也可以使用軟體完成。

    3、轉換成原生代碼

    將程式轉換成原生代碼也是一種防止反編譯的有效方法。因為原生代碼往往難以被反編譯。開發人員可以選擇將整個應用程式轉換成原生代碼,也可以選擇關鍵模組轉換。如果僅僅轉換關鍵部分模組,Java程式在使用這些模組時,需要使用JNI技術進行呼叫。

    4、程式碼混淆

    程式碼混淆是對Class檔案進行重新組織和處理,使得處理後的程式碼與處理前程式碼完成相同的功能(語義)。但是混淆後的程式碼很難被反編譯,即反編譯後得出的程式碼是非常難懂、晦澀的,因此反編譯人員很難得出程式的真正語義。從理論上來說,駭客如果有足夠的時間,被混淆的程式碼仍然可能被破解,甚至目前有些人正在研製反混淆的工具。但是從實際情況來看,由於混淆技術的多元化發展,混淆理論的成熟,經過混淆的Java程式碼還是能夠很好地防止反編譯。

  • 中秋節和大豐收的關聯?
  • 自己在家制作的滷味,準備在網上賣,大家覺得怎麼樣?