Merge pull request #300 from ThexXTURBOXx/master

Update APKTool
This commit is contained in:
Kalen (Konloch) Kinloch 2021-06-22 10:29:57 -07:00 committed by GitHub
commit b0f3e5832a
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 20 additions and 11 deletions

BIN
libs/apktool-2.5.0.jar Normal file

Binary file not shown.

Binary file not shown.

View file

@ -30,7 +30,7 @@
<artifactId>apktool</artifactId>
<version>2.3.0</version>
<scope>system</scope>
<systemPath>${project.basedir}/libs/apktool_2.3.0.jar</systemPath>
<systemPath>${project.basedir}/libs/apktool-2.5.0.jar</systemPath>
</dependency>
<dependency>
<groupId>org.ow2.asm</groupId>
@ -186,6 +186,11 @@
<artifactId>smali</artifactId>
<version>2.5.2</version>
</dependency>
<dependency>
<groupId>org.smali</groupId>
<artifactId>baksmali</artifactId>
<version>2.5.2</version>
</dependency>
<dependency>
<groupId>org.yaml</groupId>
<artifactId>snakeyaml</artifactId>

View file

@ -1,6 +1,7 @@
package the.bytecode.club.bytecodeviewer.util;
import java.io.File;
import java.lang.reflect.Field;
/***************************************************************************
* Bytecode Viewer (BCV) - Java & Android Reverse Engineering Suite *
@ -36,7 +37,9 @@ public class Dex2Jar {
*/
public static synchronized void dex2Jar(File input, File output) {
try {
com.googlecode.dex2jar.tools.Dex2jarCmd.main(input.getAbsolutePath());
com.googlecode.dex2jar.tools.Dex2jarCmd cmd = new com.googlecode.dex2jar.tools.Dex2jarCmd();
applyErrorFix(cmd);
cmd.doMain(input.getAbsolutePath());
String realOutput = input.getName().replaceAll("\\.dex", "-dex2jar.jar").replaceAll("\\.apk", "-dex2jar"
+ ".jar");
File realOutputF = new File(realOutput);
@ -44,20 +47,21 @@ public class Dex2Jar {
File realOutputF2 = new File(realOutput);
while (realOutputF2.exists())
realOutputF2.delete();
//TODO fix this properly
// WARNING: this could probably delete important error files but until a proper dex2jar fix is added this is needed
// or else after each APK decompile the file directory will be flooded with -error.zip
for(File localFile : new File(".").listFiles())
{
if(localFile.getName().length() == 42 && localFile.getName().endsWith("-error.zip"))
localFile.delete();
}
} catch (Exception e) {
new the.bytecode.club.bytecodeviewer.api.ExceptionUI(e);
}
}
// TODO fix this properly
private static void applyErrorFix(com.googlecode.dex2jar.tools.Dex2jarCmd cmd) {
try {
Field f = com.googlecode.dex2jar.tools.Dex2jarCmd.class.getDeclaredField("notHandleException");
f.setAccessible(true);
f.set(cmd, true);
} catch (Throwable ignored) {
}
}
/**
* Converts a .jar to .dex
*