Merge "Limit the number of supported v1 and v2 signers" into rvc-dev
This commit is contained in:
committed by
Android (Google) Code Review
commit
00f3afecdb
@@ -75,6 +75,11 @@ public class ApkSignatureSchemeV2Verifier {
|
||||
|
||||
private static final int APK_SIGNATURE_SCHEME_V2_BLOCK_ID = 0x7109871a;
|
||||
|
||||
/**
|
||||
* The maximum number of signers supported by the v2 APK signature scheme.
|
||||
*/
|
||||
private static final int MAX_V2_SIGNERS = 10;
|
||||
|
||||
/**
|
||||
* Returns {@code true} if the provided APK contains an APK Signature Scheme V2 signature.
|
||||
*
|
||||
@@ -183,6 +188,11 @@ public class ApkSignatureSchemeV2Verifier {
|
||||
}
|
||||
while (signers.hasRemaining()) {
|
||||
signerCount++;
|
||||
if (signerCount > MAX_V2_SIGNERS) {
|
||||
throw new SecurityException(
|
||||
"APK Signature Scheme v2 only supports a maximum of " + MAX_V2_SIGNERS
|
||||
+ " signers");
|
||||
}
|
||||
try {
|
||||
ByteBuffer signer = getLengthPrefixedSlice(signers);
|
||||
X509Certificate[] certs = verifySigner(signer, contentDigests, certFactory);
|
||||
|
||||
@@ -78,6 +78,11 @@ class StrictJarVerifier {
|
||||
"SHA1",
|
||||
};
|
||||
|
||||
/**
|
||||
* The maximum number of signers supported by the JAR signature scheme.
|
||||
*/
|
||||
private static final int MAX_JAR_SIGNERS = 10;
|
||||
|
||||
private final String jarName;
|
||||
private final StrictJarManifest manifest;
|
||||
private final HashMap<String, byte[]> metaEntries;
|
||||
@@ -293,10 +298,16 @@ class StrictJarVerifier {
|
||||
return false;
|
||||
}
|
||||
|
||||
int signerCount = 0;
|
||||
Iterator<String> it = metaEntries.keySet().iterator();
|
||||
while (it.hasNext()) {
|
||||
String key = it.next();
|
||||
if (key.endsWith(".DSA") || key.endsWith(".RSA") || key.endsWith(".EC")) {
|
||||
if (++signerCount > MAX_JAR_SIGNERS) {
|
||||
throw new SecurityException(
|
||||
"APK Signature Scheme v1 only supports a maximum of " + MAX_JAR_SIGNERS
|
||||
+ " signers");
|
||||
}
|
||||
verifyCertificate(key);
|
||||
it.remove();
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user