8358159: Empty mode/padding in cipher transformations
Reviewed-by: amitkumar, valeriep
This commit is contained in:
parent
7c9c8ba363
commit
3ff83ec49e
@ -454,19 +454,25 @@ public class Cipher {
|
|||||||
String[] parts = tokenizeTransformation(transformation);
|
String[] parts = tokenizeTransformation(transformation);
|
||||||
|
|
||||||
String alg = parts[0];
|
String alg = parts[0];
|
||||||
String mode = parts[1];
|
String mode = (parts[1].length() == 0 ? null : parts[1]);
|
||||||
String pad = parts[2];
|
String pad = (parts[2].length() == 0 ? null : parts[2]);
|
||||||
|
|
||||||
if ((mode.length() == 0) && (pad.length() == 0)) {
|
if ((mode == null) && (pad == null)) {
|
||||||
// Algorithm only
|
// Algorithm only
|
||||||
Transform tr = new Transform(alg, "", null, null);
|
Transform tr = new Transform(alg, "", null, null);
|
||||||
return Collections.singletonList(tr);
|
return Collections.singletonList(tr);
|
||||||
} else {
|
} else {
|
||||||
// Algorithm w/ at least mode or padding or both
|
// Algorithm w/ at least mode or padding or both
|
||||||
List<Transform> list = new ArrayList<>(4);
|
List<Transform> list = new ArrayList<>(4);
|
||||||
|
if ((mode != null) && (pad != null)) {
|
||||||
list.add(new Transform(alg, "/" + mode + "/" + pad, null, null));
|
list.add(new Transform(alg, "/" + mode + "/" + pad, null, null));
|
||||||
|
}
|
||||||
|
if (mode != null) {
|
||||||
list.add(new Transform(alg, "/" + mode, null, pad));
|
list.add(new Transform(alg, "/" + mode, null, pad));
|
||||||
|
}
|
||||||
|
if (pad != null) {
|
||||||
list.add(new Transform(alg, "//" + pad, mode, null));
|
list.add(new Transform(alg, "//" + pad, mode, null));
|
||||||
|
}
|
||||||
list.add(new Transform(alg, "", mode, pad));
|
list.add(new Transform(alg, "", mode, pad));
|
||||||
return list;
|
return list;
|
||||||
}
|
}
|
||||||
|
56
test/jdk/javax/crypto/Cipher/TestEmptyModePadding.java
Normal file
56
test/jdk/javax/crypto/Cipher/TestEmptyModePadding.java
Normal file
@ -0,0 +1,56 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2025, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* Copyright (c) 2025 IBM Corporation. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* @test
|
||||||
|
* @bug 8358159
|
||||||
|
* @summary test that the Cipher.getInstance() handles
|
||||||
|
* transformations with empty mode and/or padding
|
||||||
|
* @run main TestEmptyModePadding
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
import java.security.*;
|
||||||
|
import javax.crypto.*;
|
||||||
|
|
||||||
|
public class TestEmptyModePadding {
|
||||||
|
|
||||||
|
public static void main(String[] args) throws Exception {
|
||||||
|
Provider provider = Security.getProvider(System.getProperty("test.provider.name", "SunJCE"));
|
||||||
|
|
||||||
|
test("AES", provider);
|
||||||
|
test("AES/ECB/PKCS5Padding", provider);
|
||||||
|
test("AES//PKCS5Padding", provider); // Empty mode
|
||||||
|
test("AES/CBC/", provider); // Empty padding
|
||||||
|
test("AES/ /NoPadding", provider); // Mode is a space
|
||||||
|
test("AES/CBC/ ", provider); // Padding is a space
|
||||||
|
test("AES/ / ", provider); // Both mode and padding are spaces
|
||||||
|
test("AES//", provider); // Both mode and padding are missing
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void test(String transformation, Provider provider) throws Exception {
|
||||||
|
Cipher c = Cipher.getInstance(transformation, provider);
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user