-
-
Notifications
You must be signed in to change notification settings - Fork 3.6k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
fix: decoding APK with many compact entries and unknown uses-sdk attrs (
#3705) * fix: decoding APK with many compact entries and unknown uses-sdk attrs This fixes 2 new issues with a stock APK sourced from an Android 15 ROM. https://drive.google.com/file/d/1x9udLN4W5I7chyGp1ZY8Cyfhu1vXezU9/view 1) mIn.readShort() for size in readEntryData is incorrect and the size < 0 check is not possible. Entry size is stored by AAPT2 as an unsigned short and thus will never be negative. Reading it as a signed short will cause negative entry sizes in compactly packed entries in very large string pools and will result in a lot of "APKTOOL_DUMMYVAL_" values. 2) sdkInfo isn't stored properly for APKs with unexpected properties in uses-sdk tag. As far as I can tell, these attributes serve no purpose and can be ignored. In the given APK, additional "android:versionCode" and "android:versionName" attributes appear in the uses-sdk tag, purpose unknown and they don't represent the actual version of the app. E: uses-sdk (line=26) A: http://schemas.android.com/apk/res/android:minSdkVersion(0x0101020c)=35 A: http://schemas.android.com/apk/res/android:versionCode(0x0101021b)=31 A: http://schemas.android.com/apk/res/android:versionName(0x0101021c)="3.1" A: http://schemas.android.com/apk/res/android:targetSdkVersion(0x01010270)=35 * test: add assertion for issue 3705 --------- Co-authored-by: Connor Tumbleson <[email protected]> Co-authored-by: Connor Tumbleson <[email protected]>
- Loading branch information
1 parent
5c99919
commit 24541c3
Showing
8 changed files
with
137 additions
and
68 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
67 changes: 67 additions & 0 deletions
67
brut.apktool/apktool-lib/src/test/java/brut/androlib/decode/LargeCompactResourceTest.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,67 @@ | ||
/* | ||
* Copyright (C) 2010 Ryszard Wiśniewski <[email protected]> | ||
* Copyright (C) 2010 Connor Tumbleson <[email protected]> | ||
* | ||
* Licensed under the Apache License, Version 2.0 (the "License"); | ||
* you may not use this file except in compliance with the License. | ||
* You may obtain a copy of the License at | ||
* | ||
* https://www.apache.org/licenses/LICENSE-2.0 | ||
* | ||
* Unless required by applicable law or agreed to in writing, software | ||
* distributed under the License is distributed on an "AS IS" BASIS, | ||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
* See the License for the specific language governing permissions and | ||
* limitations under the License. | ||
*/ | ||
package brut.androlib.decode; | ||
|
||
import brut.androlib.*; | ||
import brut.directory.ExtFile; | ||
import brut.common.BrutException; | ||
import brut.util.OS; | ||
import java.io.File; | ||
import java.io.IOException; | ||
|
||
import org.junit.*; | ||
import org.w3c.dom.Document; | ||
import org.xml.sax.SAXException; | ||
|
||
import javax.xml.parsers.ParserConfigurationException; | ||
|
||
import static org.junit.Assert.*; | ||
|
||
public class LargeCompactResourceTest extends BaseTest { | ||
|
||
@BeforeClass | ||
public static void beforeClass() throws Exception { | ||
TestUtils.cleanFrameworkFile(); | ||
sTmpDir = new ExtFile(OS.createTempDirectory()); | ||
TestUtils.copyResourceDir(CompactResourceTest.class, "decode/issue3705/", sTmpDir); | ||
} | ||
|
||
@AfterClass | ||
public static void afterClass() throws BrutException { | ||
OS.rmdir(sTmpDir); | ||
} | ||
|
||
@Test | ||
public void checkIfDecodeSucceeds() throws BrutException, IOException, ParserConfigurationException, SAXException { | ||
String apk = "issue3705.apk"; | ||
ExtFile testApk = new ExtFile(sTmpDir, apk); | ||
|
||
// decode issue3705.apk | ||
ApkDecoder apkDecoder = new ApkDecoder(testApk); | ||
sTestOrigDir = new ExtFile(sTmpDir + File.separator + apk + ".out"); | ||
|
||
File outDir = new File(sTmpDir + File.separator + apk + ".out"); | ||
apkDecoder.decode(outDir); | ||
|
||
Document doc = loadDocument(new File(sTestOrigDir + "/res/values/strings.xml")); | ||
assertFalse(resourceNameContains(doc.getDocumentElement(), "APKTOOL")); | ||
|
||
Config config = Config.getDefaultConfig(); | ||
LOGGER.info("Building issue3705.apk..."); | ||
new ApkBuilder(sTestOrigDir, config).build(testApk); | ||
} | ||
} |
Binary file added
BIN
+1.06 MB
brut.apktool/apktool-lib/src/test/resources/decode/issue3705/issue3705.apk
Binary file not shown.