教大家防止Jar包被反编译

时间:2024-04-10 19:11:40

方法就是,向Jar注入无效代码(不合法的,或者根本不是代码的字符串)。

 

那么无效的代码又怎么能正确运行呢?

 

答案就是,你要保证你的代码永远不会执行到那一步。

 

我作一个简单的例子说明:

我们建立一个项目:

教大家防止Jar包被反编译

 

[java] view plain copy

  1. package com.TestJar;  
  2.   
  3. public class Main {  
  4.   
  5.     public static void main(String[] args){  
  6.         System.out.println(Info.getMessage());  
  7.     }  
  8. }  

 

[java] view plain copy

  1. package com.TestJar;  
  2.   
  3. public class Info {  
  4.   
  5.     public static String getMessage(){  
  6.         return "Hello World!";  
  7.     }  
  8.       
  9.     private class Invalid{  
  10.           
  11.     }  
  12. }  

 

很简单,运行结果是 Hello World!


然后我们将Info类输出Jar

教大家防止Jar包被反编译

 

现在项目改成这样:

教大家防止Jar包被反编译

 

运行结果仍然是 Hello World!

 

我们用jd-gui反编译看看:

教大家防止Jar包被反编译

 

反编译看得清清楚楚。

 

我们的私有内部类Invalid在程序中是没有用。

 

现在,我们向Invalid类注入无效代码。

注入方法很简单,用WinRar之类的解压软件打开,修改,然后保存就行了

 

打开这个Invalid内部类

教大家防止Jar包被反编译

 

我们将图中所选择的字符'd'删除

教大家防止Jar包被反编译

 

然后保存

教大家防止Jar包被反编译

 

刷新一下,程序仍然运行:Hello World!

教大家防止Jar包被反编译

 

再用jd-gui打开Info.jar

教大家防止Jar包被反编译

它反编译到那里就出错了。

 

注意不能将这个方法运行用Android项目上,Android有另一套规则,它需要把Jar转换成dex的。

转载于:https://my.oschina.net/airship/blog/853456