Path: blob/master/test/jdk/java/security/cert/CertPathValidator/nameConstraints/NameConstraintsWithRID.java
41161 views
/*1* Copyright (c) 2009, Oracle and/or its affiliates. All rights reserved.2* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.3*4* This code is free software; you can redistribute it and/or modify it5* under the terms of the GNU General Public License version 2 only, as6* published by the Free Software Foundation.7*8* This code is distributed in the hope that it will be useful, but WITHOUT9* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or10* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License11* version 2 for more details (a copy is included in the LICENSE file that12* accompanied this code).13*14* You should have received a copy of the GNU General Public License version15* 2 along with this work; if not, write to the Free Software Foundation,16* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.17*18* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA19* or visit www.oracle.com if you need additional information or have any20* questions.21*/2223/**24* @test25*26* @bug 684528627* @summary Add regression test for name constraints28* @author Xuelei Fan29*/3031import java.io.*;32import java.net.SocketException;33import java.util.*;34import java.security.Security;35import java.security.cert.*;36import java.security.cert.CertPathValidatorException.BasicReason;3738public class NameConstraintsWithRID {3940static String selfSignedCertStr =41"-----BEGIN CERTIFICATE-----\n" +42"MIICTjCCAbegAwIBAgIJAIoSzC1A/k4vMA0GCSqGSIb3DQEBBQUAMB8xCzAJBgNV\n" +43"BAYTAlVTMRAwDgYDVQQKEwdFeGFtcGxlMB4XDTA5MDUwNzA5MjcxMloXDTMwMDQx\n" +44"NzA5MjcxMlowHzELMAkGA1UEBhMCVVMxEDAOBgNVBAoTB0V4YW1wbGUwgZ8wDQYJ\n" +45"KoZIhvcNAQEBBQADgY0AMIGJAoGBANXzlv5Fn2cdgBRdEK/37/o8rqQXIRIMZqX6\n" +46"BPuo46Cdhctv+n3hu5bj/PwgJVbAJcqcQfDudSSF5gwGlRqDX9vekPSS47XZXjOZ\n" +47"qFcnDoWP0gSQXLYVVtjuItkecTrPyUE5v2lRIAh13MGKOSh3ZsrtFvj7Y5d9EqIP\n" +48"SLxWWPuHAgMBAAGjgZEwgY4wHQYDVR0OBBYEFFydJvQMB2j4EDHW2bQabNsPUvDt\n" +49"ME8GA1UdIwRIMEaAFFydJvQMB2j4EDHW2bQabNsPUvDtoSOkITAfMQswCQYDVQQG\n" +50"EwJVUzEQMA4GA1UEChMHRXhhbXBsZYIJAIoSzC1A/k4vMA8GA1UdEwEB/wQFMAMB\n" +51"Af8wCwYDVR0PBAQDAgIEMA0GCSqGSIb3DQEBBQUAA4GBAHgoopmZ1Q4qXhMDbbYQ\n" +52"YCi4Cg6cXPFblx5gzhWu/6l9SkvZbAZiLszgyMq5dGj9WyTtibNEp232dQsKTFu7\n" +53"3ag0DiFqoQ8btgvbwBlzhnRagoeVFjhuBBQutOScw7x8NCSBkZQow+31127mwu3y\n" +54"YGYhEmI2dNmgbv1hVYTGmLXW\n" +55"-----END CERTIFICATE-----";5657static String subCaCertStr =58"-----BEGIN CERTIFICATE-----\n" +59"MIICdTCCAd6gAwIBAgIJAL+MYVyy7k5YMA0GCSqGSIb3DQEBBQUAMB8xCzAJBgNV\n" +60"BAYTAlVTMRAwDgYDVQQKEwdFeGFtcGxlMB4XDTA5MDUwNzA5MjcxNFoXDTI5MDEy\n" +61"MjA5MjcxNFowMTELMAkGA1UEBhMCVVMxEDAOBgNVBAoTB0V4YW1wbGUxEDAOBgNV\n" +62"BAsTB0NsYXNzLTEwgZ8wDQYJKoZIhvcNAQEBBQADgY0AMIGJAoGBAM2mwX8dhP3M\n" +63"i6ATRsd0wco+c7rsyEbP0CRQunVIP8/kOL8+zyQix+QZquY23tvBCbia424GXDkT\n" +64"irvK/M4yGzrdS51hA5dlH3SHY3CWOAqEPqKtNLn1My4MWtTiUWbHi0YjFuOv0BXz\n" +65"x9lTEfMf+3QcOgO5FitcqHIMP4jIlT+lAgMBAAGjgaYwgaMwHQYDVR0OBBYEFJHg\n" +66"eyEWcjxcAwc01BPQrau/4HJaME8GA1UdIwRIMEaAFFydJvQMB2j4EDHW2bQabNsP\n" +67"UvDtoSOkITAfMQswCQYDVQQGEwJVUzEQMA4GA1UEChMHRXhhbXBsZYIJAIoSzC1A\n" +68"/k4vMA8GA1UdEwEB/wQFMAMBAf8wCwYDVR0PBAQDAgIEMBMGA1UdHgQMMAqhCDAG\n" +69"iAQqAwQFMA0GCSqGSIb3DQEBBQUAA4GBAI3CDQWZiTlVVVqfCiZwc/yIL7G5bu2g\n" +70"ccgVz9PyKfTpq8vk59S23TvPwdPt4ZVx4RSoar9ONtbrcLxfP3X6WQ7e9popWNZV\n" +71"q49YfyU1tD5HFuxj7CAsvfykuRo4ovXaTCVWlTMi7fJJdzU0Eb4xkXXhiWT/RbHG\n" +72"R7J+8ROMZ+nR\n" +73"-----END CERTIFICATE-----";7475static String targetCertStr =76"-----BEGIN CERTIFICATE-----\n" +77"MIICUDCCAbmgAwIBAgIJAOA8c10w019XMA0GCSqGSIb3DQEBBQUAMDExCzAJBgNV\n" +78"BAYTAlVTMRAwDgYDVQQKEwdFeGFtcGxlMRAwDgYDVQQLEwdDbGFzcy0xMB4XDTA5\n" +79"MDUwNzEwMjY0M1oXDTI5MDEyMjEwMjY0M1owQTELMAkGA1UEBhMCVVMxEDAOBgNV\n" +80"BAoTB0V4YW1wbGUxEDAOBgNVBAsTB0NsYXNzLTExDjAMBgNVBAMTBVN1c2FuMIGf\n" +81"MA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDlmyS8SskMX3mreD95oBaXUGNvPTK0\n" +82"39IBdxle2TpJEBL/BcS4QUb2+67WjrXhUZWFtpc4RzywfvSSxZH2wbwDDJPs56OC\n" +83"Eczsdnqe7gOroYm2TMfY0/pItgP3mRkhJpxAWFc/y7Qr8jJbPmKfiYbYROp1eR2t\n" +84"BrjUiUTrAtM7GwIDAQABo2AwXjALBgNVHQ8EBAMCA+gwDwYDVR0RBAgwBogEKgME\n" +85"BTAdBgNVHQ4EFgQUyqtfkWtPah5J658LHN8CEGIgAbgwHwYDVR0jBBgwFoAUkeB7\n" +86"IRZyPFwDBzTUE9Ctq7/gclowDQYJKoZIhvcNAQEFBQADgYEAnwaLBteuJhXF56Rg\n" +87"l8FIEzgJtT4yu/8WsYjhN6/aLGkgJ37VavWdhjwXIb1RVJE/ab3hTbWF5ht7jMcQ\n" +88"/WnD8R8CpwEEX/n2wpb3zMHZ8zT7k0mWYm10mPHw1psjOUvJd/zB4gT4tc2A2soM\n" +89"FbcNIaCtg8blO5ImdOz5hAi+NuY=\n" +90"-----END CERTIFICATE-----";9192private static CertPath generateCertificatePath()93throws CertificateException {94// generate certificate from cert strings95CertificateFactory cf = CertificateFactory.getInstance("X.509");9697ByteArrayInputStream is;9899is = new ByteArrayInputStream(targetCertStr.getBytes());100Certificate targetCert = cf.generateCertificate(is);101102is = new ByteArrayInputStream(subCaCertStr.getBytes());103Certificate subCaCert = cf.generateCertificate(is);104105is = new ByteArrayInputStream(selfSignedCertStr.getBytes());106Certificate selfSignedCert = cf.generateCertificate(is);107108// generate certification path109List<Certificate> list = Arrays.asList(new Certificate[] {110targetCert, subCaCert, selfSignedCert});111112return cf.generateCertPath(list);113}114115private static Set<TrustAnchor> generateTrustAnchors()116throws CertificateException {117// generate certificate from cert string118CertificateFactory cf = CertificateFactory.getInstance("X.509");119120ByteArrayInputStream is =121new ByteArrayInputStream(selfSignedCertStr.getBytes());122Certificate selfSignedCert = cf.generateCertificate(is);123124// generate a trust anchor125TrustAnchor anchor =126new TrustAnchor((X509Certificate)selfSignedCert, null);127128return Collections.singleton(anchor);129}130131public static void main(String args[]) throws Exception {132CertPath path = generateCertificatePath();133Set<TrustAnchor> anchors = generateTrustAnchors();134135PKIXParameters params = new PKIXParameters(anchors);136137// disable certificate revocation checking138params.setRevocationEnabled(false);139140// set the validation time141params.setDate(new Date(109, 5, 8)); // 2009-05-01142143// disable OCSP checker144Security.setProperty("ocsp.enable", "false");145146// disable CRL checker147System.setProperty("com.sun.security.enableCRLDP", "false");148149CertPathValidator validator = CertPathValidator.getInstance("PKIX");150151try {152validator.validate(path, params);153throw new Exception(154"the subjectAltName is excluded by NameConstraints, " +155"should thrown CertPathValidatorException");156} catch (CertPathValidatorException uoe) {157// that is the expected exception.158}159}160}161162163