[发明专利]一种基于动态链接库的Java源码保护方法在审
申请号: | 201711225600.8 | 申请日: | 2017-11-29 |
公开(公告)号: | CN107992723A | 公开(公告)日: | 2018-05-04 |
发明(设计)人: | 苏祖辉;支兵 | 申请(专利权)人: | 南京莱斯信息技术股份有限公司 |
主分类号: | G06F21/14 | 分类号: | G06F21/14;G06F9/445 |
代理公司: | 南京苏高专利商标事务所(普通合伙)32204 | 代理人: | 张弛 |
地址: | 210000 *** | 国省代码: | 江苏;32 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 基于 动态 链接 java 源码 保护 方法 | ||
技术领域
本发明涉及网络系统中的信息安全技术领域。
背景技术
在当今软件系统开发中,B/S(Browser/Server)结构即浏览器和服务器结构的模式越来越流行。它是随着Internet技术的兴起,对C/S结构的一种变化或者改进的结构。B/S结构的优点:具有分布性特点,可以随时随地进行查询、浏览等业务处理,业务扩展简单方便,通过增加网页即可增加服务器功能,维护简单方便,只需要改变网页,即可实现所有用户的同步更新,开发简单,共享性强。大多数B/S系统以主流的J2EE技术架构为基础。
针对J2EE技术开发的Java源代码编译运行文件常用格式为Jar包或者War包等格式。一种现有的方案是将项目源码使用打成War包,并解压为文件夹的形式;将指定文件夹下的源码文件加密,降低源Class文件被直接反编译的风险;改写类加载器,通过自定义JVM类加载器,解密源码文件;混淆类加载器,通过混淆自定义类加载器,达到打乱类加载器逻辑、隐藏解密算法的目的。或者对程序源代码进行逻辑替换,保存源代码函数调用关系,并用指定字符串和分隔符替换,对函数的调用信息的对应关系进行加密生成授权文件,改写Java类加载器发送到用户终端,使用户终端解密所述授权文件与函数调用逻辑的Java代码生成源代码文件。从源代码文件中获取函数调用信息,或者用预设字符串替换核心源代码,并将替换内容加密。同时改写类加载器,在运行的时候,将代码通过授权文件对替换字符串进行解密,从而还原Java运行源代码。在实际应用中,通过利用代码混淆了源码,虽然降低了代码的可读性,但是编译后的运行代码仍然可以被反编译。如果通过修改源代码,将核心源代码内容替换成调用函数或者字符串信息,则会影响源代码的维护。
故,需要一种新的技术方案以解决上述问题。
发明内容
发明目的:提供一种Java源码保护方法,以满足防止Java运行文件被反编译的需求。
技术方案:为达到上述目的,本发明可采用如下技术方案:
一种基于动态链接库的Java源码保护方法,其特征在于,包括以下步骤:
(1)、抽取Java接口:将源代码文件进行抽取和分离函数声明接口和函数实现主体;将所有需要保护的Java源代码抽取出一套接口,接口文件中只包含Java接口和类的声明,得到源代码抽取的接口声明文件;
(2)、编译文件:将所有源代码编译打包成Class字节码文件,并解析字节码内容,记录字节码中相互依赖关系,并根据字节码内容生成C语言头文件;
(3)、生成动态链接库文件:将C语言头文件和加密模块,打包编译成动态链接库文件,生成dll或so格式文件;
(4)、对Java接口文件编译打包发布:将步骤(1)中抽取的接口文件进行编译打包,形成可供第三方开发者使用的Jar接口文件,并进行分发;
(5)、设置加载本地lib包:将步骤(3)生成的包含所有Java字节码内容的dll或so文件部署到运行环境中,并设置JVM-agentlib启动参数;
(6)、动态加载动态链接库内容:在程序运行过程中,通过类加载器动态将动态链接库中加密的Java字节码内容装在到JVM中,实现完整Java字节码的加载运行。
有益效果:
本发明将实现一种基于动态链接库的Java源代码保护方法及装置,主要针对Java代码难以保护,容易被反编译、无法有效保护核心代码,无法防止程序被非法复制和传播的问题,提出了一种基于动态链接库的Java源码保护方法及装置,可将Java源代码编译打包成动态链接库文件,通过发布Java接口文件,动态加载动态链接库文件,从而达到保护Java源代码避免被发编译。可避免Java混淆代码被反编译,同时避免替换Java源代码内容造成的代码维护困难。
进一步的,步骤(2)中,将所有源代码通过Ant,Maven等工具编译打包成Class字节码文件。
进一步的,步骤(5)中JVM-agentlib启动参数设置方法为:agentlib:libname[=options],设置libname为本地代理库文件名;在Windows平台上JVM搜索本地库名为libname.dll的文件,在linux平台上JVM搜索本地库名为libname.so的文件。
进一步的,JVM为Java虚拟机。
进一步的,该方法应用于B/S结构。
附图说明
图1为本发明中Java源码保护方法的示意图。
具体实施方式
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于南京莱斯信息技术股份有限公司,未经南京莱斯信息技术股份有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201711225600.8/2.html,转载请声明来源钻瓜专利网。
- 上一篇:基于对称不确定性和信息交互增益的特征选择方法
- 下一篇:一种软件安全加固方法