Path: blob/master/test/jdk/sun/security/validator/CertReplace.java
41149 views
/*1* Copyright (c) 2010, 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* This test is called by certreplace.sh25*/2627import java.io.FileInputStream;28import java.security.KeyStore;29import java.security.cert.Certificate;30import java.security.cert.CertificateFactory;31import java.security.cert.X509Certificate;32import java.util.Arrays;33import java.util.ArrayList;34import java.util.List;35import sun.security.validator.Validator;3637public class CertReplace {3839/**40* @param args {cacerts keystore, cert chain}41*/42public static void main(String[] args) throws Exception {4344KeyStore ks = KeyStore.getInstance("JKS");45ks.load(new FileInputStream(args[0]), "changeit".toCharArray());46Validator v = Validator.getInstance47(Validator.TYPE_PKIX, Validator.VAR_GENERIC, ks);48X509Certificate[] chain = createPath(args[1]);49System.out.println("Chain: ");50for (X509Certificate c: v.validate(chain)) {51System.out.println(" " + c.getSubjectX500Principal() +52" issued by " + c.getIssuerX500Principal());53}54}5556public static X509Certificate[] createPath(String chain) throws Exception {57CertificateFactory cf = CertificateFactory.getInstance("X.509");58List list = new ArrayList();59for (Certificate c: cf.generateCertificates(60new FileInputStream(chain))) {61list.add((X509Certificate)c);62}63return (X509Certificate[]) list.toArray(new X509Certificate[0]);64}65}666768