代码混淆之class-winter

Posted justry_deng

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了代码混淆之class-winter相关的知识,希望对你有一定的参考价值。

郑重声明

  class-winter是本人在学习完class-final(v1.1.9)后,仿照class-final进行编写的,整体思路与class-final一致,代码部分(约20%~30%)复用了class-final中的代码。可将class-winter看作是class-final的一个分支。

功能与特性

  • 支持war加密。
  • 支持jar(普通jar+可执行jar)加密。

加密

  • 方式一:通过maven插件自动加密。

    <!--
        class-winter插件
        注:自Maven3.0.3起, 绑定到同一phase的Maven插件将按照pom.xml中声明的顺序执行
        注:此插件最好放置在同一phase的最后执行。
    -->
    <plugin>
        <groupId>com.idea-aedi</groupId>
        <artifactId>class-winter-maven-plugin</artifactId>
        <version>1.0.0</version>
        <!-- 相关配置 -->
        <configuration>
            <!-- <finalName></finalName>-->
            <includePrefix>加密范围</includePrefix>
            <!-- <excludePrefix></excludePrefix>-->
            <!-- <password></password>-->
            <!-- <includeLibs></includeLibs>-->
            <!-- <alreadyProtectedLibs></alreadyProtectedLibs>-->
            <!-- <supportFile></supportFile>-->
            <!-- <tips></tips>-->
            <!-- <debug></debug>-->
        </configuration>
        <executions>
            <execution>
                <phase>package</phase>
                <goals>
                    <goal>class-winter</goal>
                </goals>
            </execution>
        </executions>
    </plugin>
    

    注:不必担心信息泄漏问题,使用此方式生成混淆的jar包时,会擦除pom.xml中关于class-winter-plugin的信息。

  • 方式二:通过class-winter-core.jar主动加密。

    java -jar class-winter-core-${version}.jar originJarOrWar=${要加密的项目.jar或.war包} includePrefix=${加密范围} [k3=v3 k4=v4 ...]
    # 对于复杂的参数值,可以使用引号引起来
    # linux
    java -jar class-winter-core-${version}.jar k1='v1' k2='v2'
    # windows
    java -jar class-winter-core-${version}.jar k1="v1" k2="v2"
    

加密参数

参数是否必填说明示例
originJarOrWar指定要加密的jar/war文件
注:当使用maven插件进行自动加密时,无此参数。
originJarOrWar=/my-project.jar
includePrefix通过前缀匹配的形式定位要加密的class
注:多个通过逗号分割。
includePrefix=com
includePrefix=com,org
excludePrefix通过前缀匹配的形式排除class,不对其加密
注:多个通过逗号分割。
注:excludePrefix优先级高于includePrefix。
excludePrefix=com.example.service,com.example.util.StrUtil.class
finalName指定加密后生成的jar包名
注:若finalName与加密的包一致,那么生成的加密后的包会覆盖原来的包。
finalName=mine-project
password主动指定密码
注:密码不能包含空格和逗号。
password=123456
includeLibs指定将lib包也纳入加密范围内
注:多个通过逗号分割。
注:lib中的class是否会被加密,还得由includePrefix和excludePrefix决定。
includeLibs=a.jar,b.jar
alreadyProtectedLibs指明项目所以来的lib中,哪些lib本身就已经是被class-winter加密了的
注:多个通过逗号分割。
注:主要用于处理第三方提供的由class-winter加密了的依赖包的场景。
注:若lib需要密码,那么需要在指定lib的同时通过冒号接上密码。
注:如果lib有密码,那么密码不能包含逗号。
alreadyProtectedLibs=a.jar,b.jar
alreadyProtectedLibs=a.jar,b.jar:pwd123
alreadyProtectedLibs=a.jar:pwd1,b.jar:2
supportFile指定一个加密辅助jar文件(或jar文件所在的目录)
注:当为目录时,该目录(含子孙目录)下的所有jar都会被作采集作为辅助文件。
注:主要用于解决因ClassNotFound导致的加密失败问题。
supportFile=/abc.jar
supportFile=/libs
tips指定提示语。
注:当直接使用加密后的jar/war时,用到了加密了的类后,会先System.err.println输出此tips,然后System.exit退出程序。
windows示例:tips="请不要直接使用混淆后的jar/war"
linux示例:tips='请不要直接使用混淆后的jar/war'
debug是否开启debug模式debug=true

解密(启动)

通过-javaagent指定代理进行解密启动。

  • jar解密(启动)

    # 假设your-project-encrypted.jar是由class-winter加密后的包,那么你可以这么启动
    java -javaagent:/your-project-encrypted.jar -jar /your-project-encrypted.jar
    # 也可以用class-winter-core-1.0.0.jar
    # java -javaagent:/class-winter-core-1.0.0.jar -jar /your-project-encrypted.jar
    # 或者指定参数
    # java -javaagent:/your-project-encrypted.jar=debug=true,password=pwd12345 -jar /your-project-encrypted.jar
    # 参数可以引起来(linux)
    # java -javaagent:/your-project-encrypted.jar='debug=true,password=pwd12345' -jar /your-project-encrypted.jar
    # 参数可以引起来(windows)
    # java -javaagent:/your-project-encrypted.jar="debug=true,password=pwd12345" -jar /your-project-encrypted.jar
    
  • war解密(启动)

    • linux方式一

      编辑tomcat/bin/catalina.sh文件,在最上面加上

      # 如果你有参数, 那么 -javaagent:/class-winter-core-1.0.0.jar=k1=v1,k2=v2
      CATALINA_OPTS="$CATALINA_OPTS -javaagent:/class-winter-core-1.0.0.jar=debug=true";
      export CATALINA_OPTS;
      
    • linux方式二

      在tomcat/bin目录下创建setenv.sh文件,并写上

      # 如果你有参数, 那么 -javaagent:/class-winter-core-1.0.0.jar=k1=v1,k2=v2
      JAVA_OPTS="$JAVA_OPTS -javaagent:/class-winter-core-1.0.0.jar=debug=true";
      export JAVA_OPTS;
      
    • windows方式一

      编辑tomcat/bin/catalina.bat文件,在@echo off后加上catalina参数

      rem 如果你有参数, 那么 -javaagent:D:/class-winter-core-1.0.0.jar=k1=v1,k2=v2
      set CATALINA_OPTS="-javaagent:D:/class-winter-core-1.0.0.jar"
      
    • windows方式二

      在tomcat/bin目录下创建setenv.bat文件,并写上

      rem 如果你有参数, 那么 -javaagent:D:/class-winter-core-1.0.0.jar=k1=v1,k2=v2
      set JAVA_OPTS="-javaagent:D:/class-winter-core-1.0.0.jar"
      

解密参数

参数是否必填说明示例
password指定解密密码password=pwd123
debug是否开启debug模式debug=true

以上是关于代码混淆之class-winter的主要内容,如果未能解决你的问题,请参考以下文章

AndroidApp攻防之代码混淆

Android代码混淆之混淆规则

JAVA之代码混淆proguard

77.Android之代码混淆

Android代码混淆之部分类不混淆的技巧

Android 代码混淆之部分类不混淆的技巧