2007-12-01 00:00:00 +00:00
|
|
|
/*
|
2010-05-25 15:58:33 -07:00
|
|
|
* Copyright (c) 2006, Oracle and/or its affiliates. All rights reserved.
|
2007-12-01 00:00:00 +00: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.
|
|
|
|
*
|
2010-05-25 15:58:33 -07:00
|
|
|
* 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.
|
2007-12-01 00:00:00 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* @test
|
|
|
|
* @author Weijun Wang
|
|
|
|
* @bug 6418422
|
|
|
|
* @bug 6418425
|
|
|
|
* @bug 6418433
|
|
|
|
* @summary ObjectIdentifier should reject 1.2.3.-4 and throw IOException on all format errors
|
2015-05-28 10:54:48 -07:00
|
|
|
* @modules java.base/sun.security.util
|
|
|
|
* java.security.jgss
|
2007-12-01 00:00:00 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
import java.io.IOException;
|
|
|
|
import java.security.NoSuchAlgorithmException;
|
|
|
|
import org.ietf.jgss.GSSException;
|
|
|
|
import org.ietf.jgss.Oid;
|
|
|
|
import javax.crypto.EncryptedPrivateKeyInfo;
|
|
|
|
import sun.security.util.*;
|
|
|
|
import java.util.Arrays;
|
|
|
|
|
|
|
|
public class OidFormat {
|
|
|
|
public static void main(String[] args) throws Exception {
|
|
|
|
String[] badOids = {
|
|
|
|
// number problems
|
|
|
|
"0", "1", "2",
|
|
|
|
"3.1.1", "3", "4",
|
|
|
|
"1.40", "1.111.1",
|
|
|
|
"-1.2", "0,-2", "1.-2", "2.-2",
|
|
|
|
"1.2.-3.4", "1.2.3.-4",
|
|
|
|
// format problems
|
|
|
|
"aa", "aa.aa",
|
|
|
|
"", "....", "1.2..4", "1.2.3.", "1.", "1.2.", "0.1.",
|
|
|
|
"1,2",
|
|
|
|
};
|
|
|
|
|
|
|
|
for (String s: badOids) {
|
|
|
|
testBad(s);
|
|
|
|
}
|
|
|
|
|
|
|
|
String[] goodOids = {
|
|
|
|
"0.0", "0.1", "1.0", "1.2",
|
|
|
|
"0.39", "1.39", "2.47", "2.40.3.6", "2.100.3", "2.123456.3",
|
|
|
|
"1.2.3", "1.2.3445",
|
|
|
|
"1.3.6.1.4.1.42.2.17",
|
|
|
|
// 4811968: ASN.1 cannot handle huge OID components
|
2009-04-08 13:54:34 +08:00
|
|
|
"2.16.764.1.3101555394.1.0.100.2.1",
|
|
|
|
"2.2726957624935694386592435", // as huge as possible
|
|
|
|
"1.2.777777777777777777",
|
|
|
|
"1.2.888888888888888888.111111111111111.2222222222222.33333333333333333.44444444444444",
|
|
|
|
"1.2." +
|
|
|
|
"1111111111111111111111111111111111111111111111111111111111111." +
|
|
|
|
"2222222222222222222222222222222222222222222222222222222222222222." +
|
|
|
|
"333333333333333333333333333333333333333333333333333333333333333." +
|
|
|
|
"4444444444444444444444444444444444444444444444444444444." +
|
|
|
|
"55555555555555555555555555555555555555555555555555555555555555555555555." +
|
|
|
|
"666666666666666666666666666666666666666666666666666666666666666666666666666666666666666666." +
|
|
|
|
"77777777777777777777777777777777777777777777777777777777777777777777777777." +
|
|
|
|
"8888888888888888888888888888888888888888888888888888888888888888888888888888888888888888888888888." +
|
|
|
|
"9999999999999999999999999999999999999999999999999999999999999999999999999999999999999999",
|
|
|
|
"1.2.2147483647.4",
|
|
|
|
"1.2.268435456.4",
|
2007-12-01 00:00:00 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
for (String s: goodOids) {
|
|
|
|
testGood(s);
|
|
|
|
}
|
|
|
|
|
|
|
|
int[][] goodInts = {
|
|
|
|
{0,0}, {0,1}, {1,0}, {1,2},
|
|
|
|
{0,39}, {1,39}, {2,47}, {2,40,3,6}, {2,100,3}, {2,123456,3},
|
|
|
|
{1,2,3}, {1,2,3445},
|
|
|
|
{1,3,6,1,4,1,42,2,17},
|
|
|
|
};
|
|
|
|
|
|
|
|
for (int[] is: goodInts) {
|
|
|
|
testGood(is);
|
|
|
|
}
|
|
|
|
|
|
|
|
int[][] badInts = new int[][] {
|
|
|
|
{0}, {1}, {2},
|
|
|
|
{3,1,1}, {3}, {4},
|
|
|
|
{1,40}, {1,111,1},
|
|
|
|
{-1,2}, {0,-2}, {1,-2}, {2,-2},
|
|
|
|
{1,2,-3,4}, {1,2,3,-4},
|
|
|
|
};
|
|
|
|
|
|
|
|
for (int[] is: badInts) {
|
|
|
|
testBad(is);
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
static void testBad(int[] ints) throws Exception {
|
|
|
|
System.err.println("Trying " + Arrays.toString(ints));
|
|
|
|
try {
|
|
|
|
new ObjectIdentifier(ints);
|
|
|
|
throw new Exception("should be invalid ObjectIdentifier");
|
|
|
|
} catch (IOException ioe) {
|
|
|
|
System.err.println(ioe);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static void testGood(int[] ints) throws Exception {
|
|
|
|
System.err.println("Trying " + Arrays.toString(ints));
|
|
|
|
ObjectIdentifier oid = new ObjectIdentifier(ints);
|
|
|
|
DerOutputStream os = new DerOutputStream();
|
|
|
|
os.putOID(oid);
|
|
|
|
DerInputStream is = new DerInputStream(os.toByteArray());
|
|
|
|
ObjectIdentifier oid2 = is.getOID();
|
|
|
|
if (!oid.equals((Object)oid2)) {
|
|
|
|
throw new Exception("Test DER I/O fails: " + oid + " and " + oid2);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static void testGood(String s) throws Exception {
|
|
|
|
System.err.println("Trying " + s);
|
|
|
|
ObjectIdentifier oid = new ObjectIdentifier(s);
|
|
|
|
if (!oid.toString().equals(s)) {
|
|
|
|
throw new Exception("equal test fail");
|
|
|
|
}
|
|
|
|
DerOutputStream os = new DerOutputStream();
|
|
|
|
os.putOID(oid);
|
|
|
|
DerInputStream is = new DerInputStream(os.toByteArray());
|
|
|
|
ObjectIdentifier oid2 = is.getOID();
|
|
|
|
if (!oid.equals((Object)oid2)) {
|
|
|
|
throw new Exception("Test DER I/O fails: " + oid + " and " + oid2);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static void testBad(String s) throws Exception {
|
|
|
|
System.err.println("Trying " + s);
|
|
|
|
try {
|
|
|
|
new ObjectIdentifier(s);
|
|
|
|
throw new Exception("should be invalid ObjectIdentifier");
|
|
|
|
} catch (IOException ioe) {
|
|
|
|
System.err.println(ioe);
|
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
|
|
|
new Oid(s);
|
|
|
|
throw new Exception("should be invalid Oid");
|
|
|
|
} catch (GSSException gsse) {
|
|
|
|
;
|
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
|
|
|
new EncryptedPrivateKeyInfo(s, new byte[8]);
|
|
|
|
throw new Exception("should be invalid algorithm");
|
|
|
|
} catch (NoSuchAlgorithmException e) {
|
|
|
|
;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|