[發明專利]一種防止java程序被反編譯的系統有效
| 申請號: | 202110382600.9 | 申請日: | 2021-04-09 |
| 公開(公告)號: | CN113094665B | 公開(公告)日: | 2022-08-05 |
| 發明(設計)人: | 劉宇;方毅;葉新江;董霖;俞鋒鋒;陳文容;徐啟東 | 申請(專利權)人: | 每日互動股份有限公司 |
| 主分類號: | G06F21/14 | 分類號: | G06F21/14 |
| 代理公司: | 北京鍾維聯合知識產權代理有限公司 11579 | 代理人: | 丁慧玲 |
| 地址: | 310012 浙江省杭州*** | 國省代碼: | 浙江;33 |
| 權利要求書: | 查看更多 | 說明書: | 查看更多 |
| 摘要: | |||
| 搜索關鍵詞: | 一種 防止 java 程序 反編譯 系統 | ||
1.一種防止java程序被反編譯系統,其特征在于,
包括預設的加密函數、加密密鑰、解密密鑰和解密函數,處理器和存儲有計算機程序的存儲器,當所述計算機程序被處理器執行時,實現以下步驟:
步驟C1、監測編譯器是否將待處理的java源代碼全部編譯成對應的第一java字節碼,若編譯完成,則執行步驟C2;
步驟C2、掃描所述第一java字節碼,若掃描到常量字符串,則調用所述加密函數和加密密鑰將掃描到的常量字符串進行加密,得到對應的加密字符串;
步驟C3、將掃描到的常量字符串替換為所述解密函數的調用,并將所述解密函數對應的調用參數設置為該常量字符串對應的加密字符串;
當所述計算機程序被處理器執行時,還實現以下步驟:
步驟C41、將所述預設解密密鑰切分為多段解密密鑰段;
步驟C42、將所述多段解密密鑰段在所述第一java字節碼對應的class文件中分散存儲;
步驟C43、為每一解密密鑰段設置一密鑰段id,基于每一解密密鑰段的密鑰段id和對應的存儲地址建立密鑰段存儲表,所述密鑰段存儲表包括多條密鑰段記錄,每一密鑰段記錄的字段包括密鑰段id和存儲地址;
步驟C44、將所述密鑰段存儲表的記錄在所述第一java字節碼對應的class文件中分散存儲。
2.根據權利要求1所述的系統,其特征在于,
還包括Gradle插件,所述Gradle插件中配置有預設回調函數以及所述預設的加密函數、加密密鑰、解密密鑰和解密函數,
所述步驟C1基于Gradle監測編譯器是否將待處理的java源代碼全部編譯成對應的第一java字節碼,若編譯完成,則采用所述預設回調函數調取所述Gradle插件執行步驟C2;
所述步驟C2采用所述Gradle插件掃描所述第一java字節碼,若掃描到常量字符串,則調用所述加密函數和加密密鑰將掃描到的常量字符串進行加密,得到對應的加密字符串;
所述步驟C3采用所述Gradle插件將掃描到的常量字符串替換為所述解密函數的調用,并將所述解密函數對應的調用參數設置為該常量字符串對應的加密字符串。
3.根據權利要求1所述的系統,其特征在于,
所述步驟C2中,所述調用所述加密函數和加密密鑰將掃描到的常量字符串進行加密,得到對應的加密字符串,包括:
步驟C21、將掃描到的常量字符串轉換為btye數組,調用所述加密函數將所述btye數組進行加密,得到加密后的btye數組;
步驟C22、將加密后的btye數組進行編碼得到base64或base128的加密字符串。
4.根據權利要求3所述的系統,其特征在于,
所述加密函數為AES加密函數,所述解密函數為AES解密函數。
該專利技術資料僅供研究查看技術是否侵權等信息,商用須獲得專利權人授權。該專利全部權利屬于每日互動股份有限公司,未經每日互動股份有限公司許可,擅自商用是侵權行為。如果您想購買此專利、獲得商業授權和技術合作,請聯系【客服】
本文鏈接:http://www.szxzyx.cn/pat/books/202110382600.9/1.html,轉載請聲明來源鉆瓜專利網。





