本实例只对apk中lib文件夹中的文件进行分析

import java.io.File;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Enumeration;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Set;
import java.util.zip.ZipEntry;
import java.util.zip.ZipFile; public class GetReinforcementMoth { public static void main(String[] args) throws IOException {
initData();
// String apkSourceCodeDir[] = {"G:\\workspace\\...\\...\\..", "G:\\workspace\\...\\...\\.."};
String apkSourceCodeDir[] = {"D:\\develop\\apks"}; getReinforcementMothByPaths(apkSourceCodeDir); // ArrayList<String> apkSourceCodeDir= new ArrayList<String>();
//// apkSourceCodeDir.add("G:\\workspace\\...\\...\\..");
//// apkSourceCodeDir.add("G:\\workspace\\...\\...\\..");
// apkSourceCodeDir.add("E:\\workspace\\...\\...\\...\\..");
// getReinforcementMothByPaths(apkSourceCodeDir);
} /**
* 加固so集合
*/
static HashMap<String, String> reinforcementSoMaps; private static void initData() {
reinforcementSoMaps = new HashMap<>();
reinforcementSoMaps.put("libsecexe.so", "梆梆加固免费版");
reinforcementSoMaps.put("libsecmain.so", "梆梆加固免费版");
reinforcementSoMaps.put("libSecShell.so", "梆梆加固免费版");
reinforcementSoMaps.put("secData0.jar", "梆梆加固免费版");
reinforcementSoMaps.put("libSecShell-x86.so", "梆梆加固免费版"); reinforcementSoMaps.put("libDexHelper.so", "梆梆企业版");
reinforcementSoMaps.put("libDexHelper-x86.so", "梆梆企业版");
reinforcementSoMaps.put("classes.jar", "梆梆加固定制版");
reinforcementSoMaps.put("DexHelper.so", "梆梆加固定制版"); reinforcementSoMaps.put("libtup.so", "腾讯加固");
// ReinforcementSoMaps.put("libexec.so", "腾讯加固");
reinforcementSoMaps.put("libshell.so", "腾讯加固");
reinforcementSoMaps.put("mix.dex", "腾讯加固");
reinforcementSoMaps.put("mixz.dex", "腾讯加固");
reinforcementSoMaps.put("libshella-xxxx.so", "腾讯加固");
reinforcementSoMaps.put("libshellx-xxxx.so", "腾讯加固"); reinforcementSoMaps.put("libtosprotection.armeabi-v7a.so", "腾讯御安全");
reinforcementSoMaps.put("libtosprotection.armeabi.so", "腾讯御安全");
reinforcementSoMaps.put("libtosprotection.x86.so", "腾讯御安全");
reinforcementSoMaps.put("tosversion", "腾讯御安全");
reinforcementSoMaps.put("libTmsdk-xxx-mfr.so", "腾讯御安全");
     reinforcementSoMaps.put("aliprotect.dat", "阿里加固");
   reinforcementSoMaps.put("libsgmain.so", "阿里加固");
   reinforcementSoMaps.put("libsgsecuritybody.so", "阿里加固");
   reinforcementSoMaps.put("libmobisec.so", "阿里加固");
   reinforcementSoMaps.put("libfakejni.so", "阿里加固");
   reinforcementSoMaps.put("libzuma.so", "阿里加固");
   reinforcementSoMaps.put("libzumadata.so", "阿里加固");
   reinforcementSoMaps.put("libpreverify1.so", "阿里加固");    reinforcementSoMaps.put("kdpdata.so", "几维加固");
   reinforcementSoMaps.put("dex.dat", "几维加固");
   reinforcementSoMaps.put("libkdp.so", "几维加固");
   reinforcementSoMaps.put("libkwscmm.so", "几维加固");
   reinforcementSoMaps.put("libkwscr.so", "几维加固");
   reinforcementSoMaps.put("libkwslinker.so", "几维加固");    reinforcementSoMaps.put("libexec.so", "爱加密");
   reinforcementSoMaps.put("libexecmain.so", "爱加密");
   reinforcementSoMaps.put("ijiami.dat", "爱加密");
   reinforcementSoMaps.put("ijiami.ajm", "爱加密");
   reinforcementSoMaps.put("af.bin", "爱加密");
   reinforcementSoMaps.put("signed.bin", "爱加密");    reinforcementSoMaps.put("libchaosvmp.so", "娜迦");
   reinforcementSoMaps.put("libddog.so", "娜迦");
   reinforcementSoMaps.put("libfdog.so", "娜迦");
   reinforcementSoMaps.put("libedog.so", "娜迦");    reinforcementSoMaps.put("libprotectClass.so", "360加固");
   reinforcementSoMaps.put("libjiagu.so", "360加固");
   reinforcementSoMaps.put("libjiagu_art.so", "360加固");
   reinforcementSoMaps.put("libjiagu_x86.so", "360加固");    reinforcementSoMaps.put("libcmvmp.so", "中国移动安全加固");
  reinforcementSoMaps.put("libmogosec_dex.so", "中国移动安全加固");
  reinforcementSoMaps.put("libmogosec_sodecrypt.so", "中国移动安全加固");
    reinforcementSoMaps.put("libmogosecurity.so", "中国移动安全加固");
    
    reinforcementSoMaps.put("libbaiduprotect.so", "百度加固");  
    reinforcementSoMaps.put("baiduprotect1.jar", "百度加固");
    reinforcementSoMaps.put("baiduprotect.jar", "百度加固");   reinforcementSoMaps.put("libuusafe.jar.so", "UU安全加固");
   reinforcementSoMaps.put("libuusafe.so", "UU安全加固");
   reinforcementSoMaps.put("libuusafeempty.so", "UU安全加固");    reinforcementSoMaps.put("dp.arm-v7.so.dat", "DexProtect加固");
   reinforcementSoMaps.put("dp.arm.so.dat", "DexProtect加固");    reinforcementSoMaps.put("libegis.so", "通付盾加固");
   reinforcementSoMaps.put("libNSaferOnly.so", "通付盾加固");    reinforcementSoMaps.put("libreincp.so", "珊瑚灵御加固");
   reinforcementSoMaps.put("libreincp_x86.so", "珊瑚灵御加固");    reinforcementSoMaps.put("libnqshield.so", "网秦加固");    reinforcementSoMaps.put("libnesec.so", "网易易盾");    reinforcementSoMaps.put("libAPKProtect.so", "APKProtect加固");    reinforcementSoMaps.put("libx3g.so", "顶象技术加固");    reinforcementSoMaps.put("libitsec.so", "海云安加固");    reinforcementSoMaps.put("libapssec.so", "盛大加固");    reinforcementSoMaps.put("librsprotect.so", "瑞星加固");    reinforcementSoMaps.put("libapktoolplus_jiagu.so", "apktoolplus加固");
  }   public static void getReinforcementMothByPaths(String[] JavaSourceCodeDirs) throws IOException {
   for (String dirPath : JavaSourceCodeDirs) {
   File fl = new File(dirPath);
   if (fl.exists()) {
   getApkFileReinforcementMoth(fl);
   }
   }
  }   public static void getReinforcementMothByPaths(ArrayList<String> JavaSourceCodeDirs) throws IOException {
   for (String dirPath : JavaSourceCodeDirs) {
   File fl = new File(dirPath);
   if (fl.exists()) {
   getApkFileReinforcementMoth(fl);
   }
   }
  }
  private static void getApkFileReinforcementMoth(File fl) throws IOException {
if (fl != null && fl.exists()) {
if (fl.isDirectory()) {
File[] listFiles = fl.listFiles();
for (File file : listFiles)
getApkFileReinforcementMoth(file);
} else if (fl.isFile() && !fl.isHidden()) {
if (fl.getName().endsWith(".apk")) {
Enumeration<? extends ZipEntry> entries = new ZipFile(fl).entries();
Set<String> libSo = new HashSet<>();
while (entries.hasMoreElements()) {
ZipEntry apk = entries.nextElement();
if (!apk.isDirectory() && apk.getName().startsWith("lib/"))
libSo.add(apk.getName().substring(apk.getName().lastIndexOf("/") + 1));
}
if (libSo.isEmpty()) { // 没有lib
System.out.println(fl.getName() + ":\t从lib中没有分析出加固方式");
return;
}
Set<String> reinforcementMoth = new HashSet<>();
// 有so
for (String libFile : libSo)
if (reinforcementSoMaps.containsKey(libFile)) {
reinforcementMoth.add(reinforcementSoMaps.get(libFile));
}
if (reinforcementMoth.size() > 0) {
System.out.println(fl.getName() + ":\t分析出加固方式为:" + reinforcementMoth.toString());
} else {
System.out.println(fl.getName() + ":\t从lib中没有分析出加固方式");
}
reinforcementMoth.clear();
}
}
}
}
}
												

Android 自动分析apk加固方式的更多相关文章

  1. Android 查看Apk签名方式V1和V2

    Android 查看Apk签名方式V1和V2 java -jar apksigner.jar verify -v my.apk -- Verifies Verified using v1 scheme ...

  2. Android实现apk插件方式换肤

    换肤思路: 1.什么时候换肤? xml加载前换肤,如果xml加载后换肤,用户将会看见换肤之前的色彩,用户体验不好. 2.皮肤是什么? 皮肤就是apk,是一个资源包,包含了颜色.图片等. 3.什么样的控 ...

  3. Android中对Apk加固(加壳)续篇之---对Native层(so文件)进行加固

    有人说Android程序用Java代码写的,再怎么弄都是不安全的,很容易破解的,现在晚上关于应用加固的技术也很多了,当然这些也可以用于商业发展的,梆梆加密和爱加密就是很好的例子,当然这两家加固的Apk ...

  4. Android动态方式破解apk终极篇(加固apk破解方式)

    一.前言 今天总算迎来了破解系列的最后一篇文章了,之前的两篇文章分别为: 第一篇:如何使用Eclipse动态调试smali源码 第二篇:如何使用IDA动态调试SO文件 现在要说的就是最后一篇了,如何应 ...

  5. Android Apk加固的初步实现思路(dex整体加固)

    一.前 言 Android Apk加固的发展已经有一段时间了,相对来说本篇博客要记录的Android加壳的实现思路是4年的东西了,已经被老鸟玩烂了,Android加固的安全厂商也不会采用这么粗犷的方式 ...

  6. Android 换肤功能的实现(Apk插件方式)

    一.概述 由于Android 没有提供一套统一的换肤机制,我猜可能是因为国外更注重功能和体验的原因 所以国内如果要做一个漂亮的换肤方案,需要自己去实现. 目前换肤的方法大概有三种方案: (1)把皮肤资 ...

  7. 基于御安全APK加固的游戏反外挂方案

    一. 前言 随着移动互联网的兴起,移动游戏市场近几年突然爆发,收入规模快速增长.根据第三方数据统计,国内移动游戏2015年市场规模已达514.6亿.由于手游市场强势兴起,而且后续增长势头会愈加猛烈.火 ...

  8. [Android Security] APK自我保护 - 字符串处理

    cp : https://segmentfault.com/a/1190000005128037 在开发过程中字符串不可避免,但是这些字符串也可能是破解的关键点,比如服务器的地址和错误提示这些敏感的字 ...

  9. APK加固之类抽取分析与修复

    0x00 简单介绍   目前我己知的APK加固主要有以下两种方式(或有其它的方式有待发现) 隐藏dex文件:通过对目标DEX文件进行整体加密或压缩方式把整个dex转换为另外一个文件存放在assets文 ...

随机推荐

  1. canvas时钟demo

    显示效果如下 源码如下: <!DOCTYPE html> <html lang="en"> <head> <meta charset=&q ...

  2. iPhone的home键进果汁了,按起来粘粘的感觉

    解决办法是按住home键转动一下,再用棉签蘸点水或者酒精都行(注意:水不要太多,不能让水渗进去),用棉签按压home 键多转几圈就好了.

  3. Unity破解不成功解决方案

    你是不是遇到过Unity新版本出来的时候就急着使用,但是安装好了,却破解不成功的问题(你之前的版本破解过).这是由于你的注册表没有彻底的删除,接下来我们图解如何清理. 1.卸载以前的版本,卸载完了删除 ...

  4. .Net 数据库(SqlServer2008)的备份、还原

    //备份代码private void Backup() { SqlConnection sqlConn = new SqlConnection(strConn); strFileName = &quo ...

  5. window.document 对象

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  6. 课后练习Javascript

    <script type="text/javascript"> alert (isNaN(prompt("输入个数字进来","只能输入数字 ...

  7. vitamio遇到的坑,都是不能播放

    在模拟器上可以运行,在真机上不能用,一点就app全退了,不知原因,没办法用as连接到真机上调试,才发现是版本过高的原因,不支持sdk 23,大家的办法都是改成21, targetSdkVersion ...

  8. Windows中与系统关联自己开发的程序(默认打开方式、图标、右击菜单等)

    1. 默认打开方式 1.1. 代码支持 在Windows下,某个特定后缀名类型的文件,如果要双击时默认用某个程序(比如自己开发的WinForm程序)打开,代码中首先肯定要支持直接根据这个文件进行下一步 ...

  9. C语言#include的用法

    1.#include 命令介绍 #include 命令是预处理命令的一种,预处理命令可以将别的源代码内容插入到所指定的位置:可以标识出只有在特定条件下才会被编译的某一段程序代码: 可以定义类似标识符功 ...

  10. 第二篇:git创建流程

    1.创建组织 2.创建 3.点击项目 创建完: 4.选择管理——>选择公钥——>添加个人公钥: 5.怎样生成公钥 5.1.如何生成ssh公钥 你可以按如下命令来生成 sshkey: ssh ...