ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

spring boot jar混淆加密

2021-11-08 11:34:07  阅读:159  来源: 互联网

标签:xjar 加密 -- spring boot jar manager 密钥


最近在做一个智能床垫的机构版项目,客户要求部署到客户那边要做代码混淆防止代码被反编译。

一:在需要加密的jar的pom.xml文件添加依赖

<!-- 设置 jitpack.io 仓库 -->
<repositories>
<repository>
<id>jitpack.io</id>
<url>https://jitpack.io</url>
</repository>
</repositories>
<!-- 添加 XJar 依赖 -->
<dependencies>
<dependency>
<groupId>com.github.core-lib</groupId>
<artifactId>xjar</artifactId>
<version>v2.0.6</version>
</dependency>

 二:执行加密命令,加密需要加密的jar

//加密的密钥
String password = "123456";
XKey xKey = XKit.key(password);
//第1个参数是源文件,第2个参数是加密后的jar文件
XBoot.encrypt("G:\\gitReps\\ocr-manager\\bin\\manager\\g.jar", "G:\\gitReps\\ocr-manager\\bin\\manager\\manager.jar", xKey);

 三:使用idea可以查看到没有加密的jar文件的class源码

 

 

 

四:加密后的源码则查看不到

 

 

 五:启动加密的jar文件


// 对于 nohup 或 javaw 这种后台启动方式,无法使用控制台来输入密码,推荐使用指定密钥文件的方式启动
nohup java -jar /path/to/encrypted.jar --xjar.keyfile=/path/to/xjar.key

//或者通过传参数的方式启动,这种源码容易泄露,不推荐使用
nohub java -jar /path/to/encrypted.jar --xjar.password=123456

参数说明
参数名称 参数含义 默认值 说明
--xjar.password 密码
--xjar.algorithm 密钥算法 AES 支持JDK所有内置算法,如AES / DES ...
--xjar.keysize 密钥长度 128 根据不同的算法选取不同的密钥长度。
--xjar.ivsize 向量长度 128 根据不同的算法选取不同的向量长度。
--xjar.keyfile 密钥文件 ./xjar.key 密钥文件相对或绝对路径。
密钥文件
密钥文件采用properties的书写格式:

password: 123456
algorithm: AES
keysize: 128
ivsize: 128

到此为止混淆完毕。

 

标签:xjar,加密,--,spring,boot,jar,manager,密钥
来源: https://www.cnblogs.com/mingyi-/p/15523407.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有