本文整理匯總了Java中java.security.cert.CertificateParsingException.printStackTrace方法的典型用法代碼示例。如果您正苦於以下問題:Java CertificateParsingException.printStackTrace方法的具體用法?Java CertificateParsingException.printStackTrace怎麽用?Java CertificateParsingException.printStackTrace使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類java.security.cert.CertificateParsingException
的用法示例。
在下文中一共展示了CertificateParsingException.printStackTrace方法的11個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: getSubjectAlternativeNames
import java.security.cert.CertificateParsingException; //導入方法依賴的package包/類
public List<String> getSubjectAlternativeNames() {
List<String> subjectAlternativeNames = new LinkedList<String>();
try {
if (certificate.getSubjectAlternativeNames() == null) {
return subjectAlternativeNames;
}
for (List<?> i : certificate.getSubjectAlternativeNames()) {
subjectAlternativeNames.add(i.get(1) + " (" + ObjectIdentifier.getSubjectAlternativeNames((Integer) i.get(0)) + ")");
}
} catch (CertificateParsingException e) {
e.printStackTrace();
}
return subjectAlternativeNames;
}
示例2: getIssuerAlternativeNames
import java.security.cert.CertificateParsingException; //導入方法依賴的package包/類
public List<String> getIssuerAlternativeNames() {
List<String> issuerAlternativeNames = new LinkedList<String>();
try {
if (certificate.getIssuerAlternativeNames() == null) {
return issuerAlternativeNames;
}
for (List<?> i : certificate.getIssuerAlternativeNames()) {
issuerAlternativeNames.add(i.get(1) + " (" + ObjectIdentifier.getSubjectAlternativeNames((Integer) i.get(0)) + ")");
}
} catch (CertificateParsingException e) {
e.printStackTrace();
}
return issuerAlternativeNames;
}
示例3: getExtendedKeyUsage
import java.security.cert.CertificateParsingException; //導入方法依賴的package包/類
public List<String> getExtendedKeyUsage() {
List<String> extendedKeyUsage = new LinkedList<>();
try {
if (certificate.getExtendedKeyUsage() == null) {
return extendedKeyUsage;
}
for (String i : certificate.getExtendedKeyUsage()) {
extendedKeyUsage.add(ObjectIdentifier.getExtendedKeyUsage(i));
}
} catch (CertificateParsingException e) {
e.printStackTrace();
}
return extendedKeyUsage;
}
示例4: getDNSSubjectAlts
import java.security.cert.CertificateParsingException; //導入方法依賴的package包/類
/**
* Extracts the array of SubjectAlt DNS names from an X509Certificate.
* Returns null if there aren't any.
* <p/>
* Note: Java doesn't appear able to extract international characters
* from the SubjectAlts. It can only extract international characters
* from the CN field.
* <p/>
* (Or maybe the version of OpenSSL I'm using to test isn't storing the
* international characters correctly in the SubjectAlts?).
*
* @param cert X509Certificate
* @return Array of SubjectALT DNS names stored in the certificate.
*/
public static String[] getDNSSubjectAlts(X509Certificate cert) {
final List<String> subjectAltList = new LinkedList<String>();
Collection<List<?>> c = null;
try {
c = cert.getSubjectAlternativeNames();
}
catch (CertificateParsingException cpe) {
// Should probably log.debug() this?
cpe.printStackTrace();
}
if (c != null) {
Iterator<List<?>> it = c.iterator();
while (it.hasNext()) {
List<?> list = it.next();
int type = ((Integer) list.get(0)).intValue();
// If type is 2, then we've got a dNSName
if (type == 2) {
String s = (String) list.get(1);
subjectAltList.add(s);
}
}
}
if (!subjectAltList.isEmpty()) {
String[] subjectAlts = new String[subjectAltList.size()];
subjectAltList.toArray(subjectAlts);
return subjectAlts;
} else {
return null;
}
}
示例5: getDNSSubjectAlts
import java.security.cert.CertificateParsingException; //導入方法依賴的package包/類
/**
* Extract all alternative names from a certificate.
* @param cert
* @return
*/
private static String[] getDNSSubjectAlts(X509Certificate cert) {
LinkedList subjectAltList = new LinkedList();
Collection c = null;
try {
c = cert.getSubjectAlternativeNames();
} catch (CertificateParsingException cpe) {
// Should probably log.debug() this?
cpe.printStackTrace();
}
if (c != null) {
Iterator it = c.iterator();
while (it.hasNext()) {
List list = (List) it.next();
int type = ((Integer) list.get(0)).intValue();
// If type is 2, then we've got a dNSName
if (type == 2) {
String s = (String) list.get(1);
subjectAltList.add(s);
}
}
}
if (!subjectAltList.isEmpty()) {
String[] subjectAlts = new String[subjectAltList.size()];
subjectAltList.toArray(subjectAlts);
return subjectAlts;
} else {
return new String[0];
}
}
示例6: getTestCertificateObject
import java.security.cert.CertificateParsingException; //導入方法依賴的package包/類
public static X509CertificateObject getTestCertificateObject() {
try {
X509CertificateObject obj = new X509CertificateObject(getTestCertificate().getCertificateAt(0));
return obj;
} catch (CertificateParsingException ex) {
ex.printStackTrace();
}
return null;
}
示例7: showAcceptedIssuers
import java.security.cert.CertificateParsingException; //導入方法依賴的package包/類
private static void showAcceptedIssuers(X509Certificate[] acceptedIssuers, StringBuilder report) {
for (int i = 0; i < acceptedIssuers.length; i++) {
try {
Collection<List<?>> subjectAlternativeNames = acceptedIssuers[i].getSubjectAlternativeNames();
if (subjectAlternativeNames == null) {
report.append(String.format("%d: %s (no subject alternatives))\n", i, acceptedIssuers[i].getSubjectX500Principal()));
} else {
report.append(String.format("%d: %s (%d subject alternatives)\n", i, acceptedIssuers[i].getSubjectX500Principal(), acceptedIssuers[i].getSubjectAlternativeNames().size()));
for (List<?> x : subjectAlternativeNames) {
int type = (Integer) x.get(0);
String value = (String) x.get(1);
switch (type) {
case 2: // dNSName per RFC5280 4.2.1.6
report.append(String.format(" subjectAlt: DNS:%s\n", value));
break;
case 7: // iPAddress per RFC5280 4.2.1.6
report.append(String.format(" subjectAlt: IP:%s\n", value));
break;
default:
report.append(String.format(" subjectAlt: [%d]:%s\n", type, value));
break;
}
}
}
} catch (CertificateParsingException e) {
e.printStackTrace();
}
}
}
示例8: getDNSSubjectAlts
import java.security.cert.CertificateParsingException; //導入方法依賴的package包/類
/**
* Extracts the array of SubjectAlt DNS names from an X509Certificate.
* Returns null if there aren't any.
* <p/>
* Note: Java doesn't appear able to extract international characters
* from the SubjectAlts. It can only extract international characters
* from the CN field.
* <p/>
* (Or maybe the version of OpenSSL I'm using to test isn't storing the
* international characters correctly in the SubjectAlts?).
*
* @param cert X509Certificate
* @return Array of SubjectALT DNS names stored in the certificate.
*/
public static String[] getDNSSubjectAlts(X509Certificate cert) {
LinkedList subjectAltList = new LinkedList();
Collection c = null;
try {
c = cert.getSubjectAlternativeNames();
}
catch (CertificateParsingException cpe) {
// Should probably log.debug() this?
cpe.printStackTrace();
}
if (c != null) {
Iterator it = c.iterator();
while (it.hasNext()) {
List list = (List) it.next();
int type = ((Integer) list.get(0)).intValue();
// If type is 2, then we've got a dNSName
if (type == 2) {
String s = (String) list.get(1);
subjectAltList.add(s);
}
}
}
if (!subjectAltList.isEmpty()) {
String[] subjectAlts = new String[subjectAltList.size()];
subjectAltList.toArray(subjectAlts);
return subjectAlts;
} else {
return null;
}
}
示例9: hostNameMessage
import java.security.cert.CertificateParsingException; //導入方法依賴的package包/類
private String hostNameMessage(X509Certificate cert, String hostname) {
StringBuffer si = new StringBuffer();
si.append(master.getString(R.string.mtm_hostname_mismatch, hostname));
si.append("\n\n");
try {
Collection<List<?>> sans = cert.getSubjectAlternativeNames();
if (sans == null) {
si.append(cert.getSubjectDN());
si.append("\n");
} else for (List<?> altName : sans) {
Object name = altName.get(1);
if (name instanceof String) {
si.append("[");
si.append((Integer) altName.get(0));
si.append("] ");
si.append(name);
si.append("\n");
}
}
} catch (CertificateParsingException e) {
e.printStackTrace();
si.append("<Parsing error: ");
si.append(e.getLocalizedMessage());
si.append(">\n");
}
si.append("\n");
si.append(master.getString(R.string.mtm_connect_anyway));
si.append("\n\n");
si.append(master.getString(R.string.mtm_cert_details));
certDetails(si, cert);
return si.toString();
}
示例10: getSubjectAlternativeNames
import java.security.cert.CertificateParsingException; //導入方法依賴的package包/類
/**
* Returns the JID representation of an XMPP entity contained as a SubjectAltName extension
* in the certificate. If none was found then return <tt>null</tt>.
*
* @param certificate the certificate presented by the remote entity.
* @return the JID representation of an XMPP entity contained as a SubjectAltName extension
* in the certificate. If none was found then return <tt>null</tt>.
*/
private static List<String> getSubjectAlternativeNames(X509Certificate certificate) {
List<String> identities = new ArrayList<String>();
try {
Collection<List<?>> altNames = certificate.getSubjectAlternativeNames();
// Check that the certificate includes the SubjectAltName extension
if (altNames == null) {
return Collections.emptyList();
}
// Use the type OtherName to search for the certified server name
/*for (List item : altNames) {
Integer type = (Integer) item.get(0);
if (type == 0) {
// Type OtherName found so return the associated value
try {
// Value is encoded using ASN.1 so decode it to get the server's identity
ASN1InputStream decoder = new ASN1InputStream((byte[]) item.toArray()[1]);
DEREncodable encoded = decoder.readObject();
encoded = ((DERSequence) encoded).getObjectAt(1);
encoded = ((DERTaggedObject) encoded).getObject();
encoded = ((DERTaggedObject) encoded).getObject();
String identity = ((DERUTF8String) encoded).getString();
// Add the decoded server name to the list of identities
identities.add(identity);
}
catch (UnsupportedEncodingException e) {
// Ignore
}
catch (IOException e) {
// Ignore
}
catch (Exception e) {
e.printStackTrace();
}
}
// Other types are not good for XMPP so ignore them
System.out.println("SubjectAltName of invalid type found: " + certificate);
}*/
}
catch (CertificateParsingException e) {
e.printStackTrace();
}
return identities;
}
示例11: verifySSLHostname
import java.security.cert.CertificateParsingException; //導入方法依賴的package包/類
protected void verifySSLHostname(final SSLSocket sslSocket) throws IOException {
if (!this.isSSLTrustALL()) {
final SSLSession sslSession = sslSocket.getSession();
if (sslSession != null && sslSession.getPeerCertificates().length > 0) {
final Certificate certificate = sslSession.getPeerCertificates()[0];
if (certificate instanceof X509Certificate) {
final String hostname = this.getURL().getHost().toLowerCase(Locale.ENGLISH);
final ArrayList<String> subjects = new ArrayList<String>();
final X509Certificate x509 = (X509Certificate) certificate;
subjects.add(new Regex(x509.getSubjectX500Principal().getName(), "CN=(.*?)(,| |$)").getMatch(0));
try {
final Collection<List<?>> subjectAlternativeNames = x509.getSubjectAlternativeNames();
if (subjectAlternativeNames != null) {
for (final List<?> subjectAlternativeName : subjectAlternativeNames) {
final Integer generalNameType = (Integer) subjectAlternativeName.get(0);
switch (generalNameType) {
case 1:// rfc822Name
case 2:// dNSName
subjects.add(subjectAlternativeName.get(1).toString());
break;
}
}
}
} catch (CertificateParsingException e) {
e.printStackTrace();
}
for (String subject : subjects) {
if (subject != null) {
subject = subject.toLowerCase(Locale.ENGLISH);
if (StringUtils.equals(subject, hostname)) {
return;
} else if (subject.startsWith("*.") && hostname.length() > subject.length() - 1 && hostname.endsWith(subject.substring(1)) && hostname.substring(0, hostname.length() - subject.length() + 1).indexOf('.') < 0) {
/**
* http://en.wikipedia.org/wiki/ Wildcard_certificate
*/
return;
}
}
}
throw new SSLHandshakeException("HTTPS hostname wrong: hostname is <" + hostname + ">");
}
}
}
}