jar包加密发布之xjar

前言

最近团队开发使用spring-boot2.0架构,需要将项目部署至其他公司,为了防止jar包源码被破解。因此对已经打包好的jar包再次进行加密进行发布。发现xjar组件比较方便,切安全性较高。代码不是混淆,文件经过加密看不见源码,可以查询效果。对比代码混淆的方式,这种方式基本不会暴露代码的变量主要逻辑等。

效果展示

   加密前通过idea开发工具查看源码:

        jar包加密发布之xjar_第1张图片

    加密后通过idea开发工具查看源码:

        jar包加密发布之xjar_第2张图片

实现过程

1.maven 依赖


    com.github.core-lib
    xjar
    v2.0.6

2.加密后,启动时不需要密码,该方式不安全

通过密码将打包好的jar包进行加密,

test-1.0-SNAPSHOT.jar为加密前的jar包 

test-release-1.0-SNAPSHOT.jar为加密后的jar包

String password = "test";
XKey xKey = null;
try {
    xKey = XKit.key(password);
    XBoot.encrypt("D:\\workdir\\target\\test-1.0-SNAPSHOT.jar", "D:\\workdi\\target\\test-release-1.0-SNAPSHOT.jar", xKey, XConstants.MODE_DANGER);
} catch (NoSuchAlgorithmException e) {
    e.printStackTrace();
} catch (Exception e) {
    e.printStackTrace();
}

3.启动时输入密码

test-1.0-SNAPSHOT.jar为加密前的jar包 

test-out-1.0-SNAPSHOT.jar为加密后的jar包

String password = "ccbc2016";
XKey xKey = null;
try {
    xKey = XKit.key(password);
    XBoot.encrypt("C:\\test\\test-1.0-SNAPSHOT.jar", "C:\\test\\test-out-1.0-SNAPSHOT.jar", xKey);
} catch (NoSuchAlgorithmException e) {
    e.printStackTrace();
} catch (Exception e) {
    e.printStackTrace();
}

4.启动

java -jar test-1.0-SNAPSHOT.jar

你可能感兴趣的:(SpringBoot2,java,spring,jar)