javaEE防盗版-ProGuard 混淆技术

这里介绍一些java的混淆技术。混淆主要是为了保护产权,增加代码反编译后的阅读难度。

本文介绍的是ProGuard来进行代码混淆,集成在Maven环境中。常规环境的混淆技术以后再做介绍了。

混淆效果简介

public class User {
    public String username;
    public String password;
    public String getMsg(){
        return ""+username + "|" + password;
    }
}

混淆后

public class AA {
    public String aa;
    public String bb;
    public String cc(){
        return ""+aa + "|" + bb;
    }
}

上面的只是伪代码,真是代码请以实际配置为准。

个人感觉混淆还是在业务逻辑比较复杂,变量多,并且有大量private方法的类中效果比较好。(因为public方法对外提供,因此不建议混淆public的方法名,但是局部变量名就无所谓了)。还有一些混淆工具会在混淆过程中添加大量无效代码。。。

POM.xml


  com.github.wvengen
  proguard-maven-plugin
  2.0.11
  
    
      
      package
      
        
        proguard
      
    
  
  
    
    true
    
    true
    
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
    
    
    
      ${java.home}/lib/rt.jar
      ${java.home}/lib/jce.jar
    
  



这里介绍一下option - keep规则吧,一般的写法就是上面那样 ** 可以匹配任意的包下的类 , {*;} 代表成员和属性都不进行混淆

{;} 代表所有的方法都不进行混淆

上面两个可以根据自己的需要进行修改,注意<>符号需要转译成< > 

详细的操作说明,官网上都有, 地址: http://proguard.sourceforge.net/


此外,为了更好的保护代码,混淆技术和加密技术联合使用效果更佳哟~,详细方案会在另一篇日志讲述~


补充

混淆内存溢出

在配置文件中加上1024m

你可能感兴趣的:(java安全,javaEE防盗版)