/* * Copyright (c) 2012, 2013, Oracle and/or its affiliates. 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 7026347 * @summary Certificate should have * verify(PublicKey key, Provider sigProvider)
*/
/* * Verify certificate with its own public key. * Should pass.
*/
verifyCert(selfSignedCertPubKey,"SunRsaSign");
/* * Try to verify certificate with a provider that does not have a * Signature implementation. * Should fail with NoSuchAlgorithmException.
*/ try {
verifyCert(selfSignedCertPubKey, "SunJCE"); thrownew RuntimeException("Didn't catch the exception properly");
} catch (NoSuchAlgorithmException e) {
System.out.println("Caught the correct exception.");
}
/* * Try to verify certificate with a provider that has a Signature * implementation but not of the right algorithm (MD5withRSA). * Should fail with NoSuchAlgorithmException.
*/ try {
verifyCert(selfSignedCertPubKey, "SUN"); thrownew RuntimeException("Didn't catch the exception properly");
} catch (NoSuchAlgorithmException e) {
System.out.println("Caught the correct exception.");
}
/* * Try to verify certificate with the wrong public key. * Should fail with SignatureException.
*/ try {
verifyCert(crlIssuerCertPubKey, "SunRsaSign"); thrownew RuntimeException("Didn't catch the exception properly");
} catch (SignatureException e) {
System.out.println("Caught the correct exception.");
}
}
/* Get public key of the CRL issuer cert */
ByteArrayInputStream inputStream
= new ByteArrayInputStream(crlIssuerCertStr.getBytes());
cert = (X509Certificate)cf.generateCertificate(inputStream);
crlIssuerCertPubKey = cert.getPublicKey();
/* Get public key of the self-signed Cert */
inputStream = new ByteArrayInputStream(selfSignedCertStr.getBytes());
selfSignedCertPubKey = cf.generateCertificate(inputStream).getPublicKey();
}
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.