2015-06-25 09:03:23 +08:00
|
|
|
/*
|
2017-08-14 21:24:45 -07:00
|
|
|
* Copyright (c) 2015, 2017, Oracle and/or its affiliates. All rights reserved.
|
2015-06-25 09:03:23 +08:00
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
2016-04-14 14:42:53 -07:00
|
|
|
/*
|
|
|
|
* @test
|
|
|
|
* @bug 8023546 8151834
|
|
|
|
* @modules java.base/sun.security.x509
|
|
|
|
* java.base/sun.security.tools.keytool
|
|
|
|
* @summary Test prime exponent (p) lengths 63 and 65 bytes with SunMSCAPI.
|
|
|
|
* The seed 76 has the fastest test execution now (only 5 rounds) and is
|
|
|
|
* hard-coded in run tag. This number might change if algorithms for
|
|
|
|
* RSA key pair generation or BigInteger prime searching gets updated.
|
|
|
|
* @requires os.family == "windows"
|
|
|
|
* @run main SmallPrimeExponentP 76
|
|
|
|
*/
|
2015-06-25 09:03:23 +08:00
|
|
|
import sun.security.tools.keytool.CertAndKeyGen;
|
|
|
|
import sun.security.x509.X500Name;
|
|
|
|
|
|
|
|
import java.security.KeyStore;
|
|
|
|
import java.security.SecureRandom;
|
|
|
|
import java.security.cert.X509Certificate;
|
|
|
|
import java.security.interfaces.RSAPrivateCrtKey;
|
2016-04-14 14:42:53 -07:00
|
|
|
import java.util.Random;
|
2015-06-25 09:03:23 +08:00
|
|
|
|
|
|
|
public class SmallPrimeExponentP {
|
|
|
|
|
|
|
|
public static void main(String argv[]) throws Exception {
|
|
|
|
|
2016-04-14 14:42:53 -07:00
|
|
|
long seed = Long.parseLong(argv[0]);
|
|
|
|
System.out.println("Seed for SecureRandom = " + seed + "L");
|
|
|
|
|
2015-06-25 09:03:23 +08:00
|
|
|
KeyStore ks = KeyStore.getInstance("Windows-MY");
|
|
|
|
ks.load(null, null);
|
2016-04-14 14:42:53 -07:00
|
|
|
|
2015-06-25 09:03:23 +08:00
|
|
|
CertAndKeyGen ckg = new CertAndKeyGen("RSA", "SHA1withRSA");
|
2016-04-14 14:42:53 -07:00
|
|
|
ckg.setRandom(new MySecureRandom(seed));
|
|
|
|
|
2017-08-14 21:24:45 -07:00
|
|
|
String alias = "anything";
|
|
|
|
int count = 0;
|
|
|
|
|
2016-04-14 14:42:53 -07:00
|
|
|
boolean see63 = false;
|
|
|
|
boolean see65 = false;
|
2015-06-25 09:03:23 +08:00
|
|
|
while (!see63 || !see65) {
|
|
|
|
ckg.generate(1024);
|
|
|
|
RSAPrivateCrtKey k = (RSAPrivateCrtKey) ckg.getPrivateKey();
|
2016-04-14 14:42:53 -07:00
|
|
|
|
2015-06-25 09:03:23 +08:00
|
|
|
int len = k.getPrimeExponentP().toByteArray().length;
|
2016-04-14 14:42:53 -07:00
|
|
|
System.out.println("Length of P = " + len);
|
2015-06-25 09:03:23 +08:00
|
|
|
if (len == 63 || len == 65) {
|
|
|
|
if (len == 63) {
|
2016-04-14 14:42:53 -07:00
|
|
|
if (see63) {
|
|
|
|
continue;
|
|
|
|
} else {
|
|
|
|
see63 = true;
|
|
|
|
}
|
2015-06-25 09:03:23 +08:00
|
|
|
}
|
|
|
|
if (len == 65) {
|
2016-04-14 14:42:53 -07:00
|
|
|
if (see65) {
|
|
|
|
continue;
|
|
|
|
} else {
|
|
|
|
see65 = true;
|
|
|
|
}
|
2015-06-25 09:03:23 +08:00
|
|
|
}
|
2017-08-14 21:24:45 -07:00
|
|
|
ks.setKeyEntry(alias, k, null, new X509Certificate[]{
|
2016-04-14 14:42:53 -07:00
|
|
|
ckg.getSelfCertificate(new X500Name("CN=Me"), 1000)
|
2015-06-25 09:03:23 +08:00
|
|
|
});
|
2017-08-14 21:24:45 -07:00
|
|
|
count++;
|
2015-06-25 09:03:23 +08:00
|
|
|
}
|
|
|
|
}
|
2017-08-14 21:24:45 -07:00
|
|
|
|
|
|
|
// Because of JDK-8185844, it has to reload the key store after
|
|
|
|
// deleting an entry.
|
|
|
|
for (int i = 0; i < count; i++) {
|
|
|
|
ks.deleteEntry(alias);
|
|
|
|
ks.load(null, null);
|
|
|
|
}
|
2015-06-25 09:03:23 +08:00
|
|
|
}
|
2016-04-14 14:42:53 -07:00
|
|
|
|
|
|
|
static class MySecureRandom extends SecureRandom {
|
|
|
|
|
|
|
|
final Random random;
|
|
|
|
|
|
|
|
public MySecureRandom(long seed) {
|
|
|
|
random = new Random(seed);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void nextBytes(byte[] bytes) {
|
|
|
|
random.nextBytes(bytes);
|
|
|
|
}
|
|
|
|
}
|
2015-06-25 09:03:23 +08:00
|
|
|
}
|