From 6e065f15a03cae199f5d2497ad7fe375e1f24483 Mon Sep 17 00:00:00 2001 From: Andrei Zhukouski Date: Sun, 17 Apr 2016 14:48:51 +0300 Subject: [PATCH 1/3] Support of official aapt Create fake AndroidManifest.xml file inside each installed framework file to support official aapt from Google. --- .../brut/androlib/res/AndrolibResources.java | 29 +++++++++++++++++++ 1 file changed, 29 insertions(+) diff --git a/brut.apktool/apktool-lib/src/main/java/brut/androlib/res/AndrolibResources.java b/brut.apktool/apktool-lib/src/main/java/brut/androlib/res/AndrolibResources.java index 9f69936f..75e73b83 100644 --- a/brut.apktool/apktool-lib/src/main/java/brut/androlib/res/AndrolibResources.java +++ b/brut.apktool/apktool-lib/src/main/java/brut/androlib/res/AndrolibResources.java @@ -621,6 +621,15 @@ final public class AndrolibResources { entry.setCrc(crc.getValue()); out.putNextEntry(entry); out.write(data); + out.closeEntry(); + + //Write fake AndroidManifest.xml file to support original aapt + byte[] manifest = createAndroidManifestFileData(); + entry = createAndroidManifestEntry(manifest); + out.putNextEntry(entry); + out.write(data); + out.closeEntry(); + zip.close(); LOGGER.info("Framework installed to: " + outFile); } catch (IOException ex) { @@ -630,6 +639,26 @@ final public class AndrolibResources { IOUtils.closeQuietly(out); } } + + private ZipEntry createAndroidManifestEntry(byte[] data) throws IOException { + ZipEntry entry = new ZipEntry("AndroidManifest.xml"); + CRC32 crc = new CRC32(); + crc.update(data); + entry.setSize(data.length); + entry.setCrc(crc.getValue()); + return entry; + } + + private byte[] createAndroidManifestFileData() throws IOException { + File temp = File.createTempFile("AndroidManifest", ".tmp"); + BufferedWriter bw = new BufferedWriter(new FileWriter(temp)); + bw.write("AndroidManifest.xml for official aapt"); + bw.close(); + InputStream in = new FileInputStream(temp); + byte[] data = IOUtils.toByteArray(in); + in.close(); + return data; + } public void publicizeResources(File arscFile) throws AndrolibException { byte[] data = new byte[(int) arscFile.length()]; From 2ec2fe817aab326f973d887332c8b92766b86f7a Mon Sep 17 00:00:00 2001 From: Andrei Zhukouski Date: Sun, 17 Apr 2016 15:02:38 +0300 Subject: [PATCH 2/3] Fix typo --- .../src/main/java/brut/androlib/res/AndrolibResources.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/brut.apktool/apktool-lib/src/main/java/brut/androlib/res/AndrolibResources.java b/brut.apktool/apktool-lib/src/main/java/brut/androlib/res/AndrolibResources.java index 75e73b83..4e8fd10e 100644 --- a/brut.apktool/apktool-lib/src/main/java/brut/androlib/res/AndrolibResources.java +++ b/brut.apktool/apktool-lib/src/main/java/brut/androlib/res/AndrolibResources.java @@ -627,7 +627,7 @@ final public class AndrolibResources { byte[] manifest = createAndroidManifestFileData(); entry = createAndroidManifestEntry(manifest); out.putNextEntry(entry); - out.write(data); + out.write(manifest); out.closeEntry(); zip.close(); From 513e4b752b7b4af4b788ea55c49d16124d6928ca Mon Sep 17 00:00:00 2001 From: Andrei Zhukouski Date: Fri, 22 Apr 2016 08:32:42 +0300 Subject: [PATCH 3/3] Copy AndroidManifest.xml Copy AndroidManifest.xml along with resources.arsc from the framework apk file instead of creating the fake entry. --- .../brut/androlib/res/AndrolibResources.java | 38 +++++++------------ 1 file changed, 13 insertions(+), 25 deletions(-) diff --git a/brut.apktool/apktool-lib/src/main/java/brut/androlib/res/AndrolibResources.java b/brut.apktool/apktool-lib/src/main/java/brut/androlib/res/AndrolibResources.java index 4e8fd10e..1088cd66 100644 --- a/brut.apktool/apktool-lib/src/main/java/brut/androlib/res/AndrolibResources.java +++ b/brut.apktool/apktool-lib/src/main/java/brut/androlib/res/AndrolibResources.java @@ -624,11 +624,19 @@ final public class AndrolibResources { out.closeEntry(); //Write fake AndroidManifest.xml file to support original aapt - byte[] manifest = createAndroidManifestFileData(); - entry = createAndroidManifestEntry(manifest); - out.putNextEntry(entry); - out.write(manifest); - out.closeEntry(); + entry = zip.getEntry("AndroidManifest.xml"); + if (entry != null) { + in = zip.getInputStream(entry); + byte[] manifest = IOUtils.toByteArray(in); + CRC32 manifestCrc = new CRC32(); + manifestCrc.update(manifest); + entry.setSize(manifest.length); + entry.setCompressedSize(-1); + entry.setCrc(manifestCrc.getValue()); + out.putNextEntry(entry); + out.write(manifest); + out.closeEntry(); + } zip.close(); LOGGER.info("Framework installed to: " + outFile); @@ -639,26 +647,6 @@ final public class AndrolibResources { IOUtils.closeQuietly(out); } } - - private ZipEntry createAndroidManifestEntry(byte[] data) throws IOException { - ZipEntry entry = new ZipEntry("AndroidManifest.xml"); - CRC32 crc = new CRC32(); - crc.update(data); - entry.setSize(data.length); - entry.setCrc(crc.getValue()); - return entry; - } - - private byte[] createAndroidManifestFileData() throws IOException { - File temp = File.createTempFile("AndroidManifest", ".tmp"); - BufferedWriter bw = new BufferedWriter(new FileWriter(temp)); - bw.write("AndroidManifest.xml for official aapt"); - bw.close(); - InputStream in = new FileInputStream(temp); - byte[] data = IOUtils.toByteArray(in); - in.close(); - return data; - } public void publicizeResources(File arscFile) throws AndrolibException { byte[] data = new byte[(int) arscFile.length()];