當前位置: 首頁>>代碼示例>>Java>>正文


Java X509Certificate類代碼示例

本文整理匯總了Java中javax.security.cert.X509Certificate的典型用法代碼示例。如果您正苦於以下問題:Java X509Certificate類的具體用法?Java X509Certificate怎麽用?Java X509Certificate使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


X509Certificate類屬於javax.security.cert包,在下文中一共展示了X509Certificate類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: getPeerCertificateChain

import javax.security.cert.X509Certificate; //導入依賴的package包/類
@Override
public Object[] getPeerCertificateChain(boolean force)
    throws IOException {
    // Look up the current SSLSession
    if (session == null)
        return null;

    // Convert JSSE's certificate format to the ones we need
    X509Certificate [] jsseCerts = null;
    try {
        jsseCerts = session.getPeerCertificateChain();
    } catch(Exception bex) {
        // ignore.
    }
    if (jsseCerts == null)
        jsseCerts = new X509Certificate[0];
    if(jsseCerts.length <= 0 && force && ssl != null) {
        session.invalidate();
        handShake();
        session = ssl.getSession();
    }
    return getX509Certificates(session);
}
 
開發者ID:liaokailin,項目名稱:tomcat7,代碼行數:24,代碼來源:JSSESupport.java

示例2: processX509CertConnect

import javax.security.cert.X509Certificate; //導入依賴的package包/類
private void processX509CertConnect(ChannelHandlerContext ctx, X509Certificate cert, String clientIdentifier) {
  try {
    String strCert = SslUtil.getX509CertificateString(cert);
    String sha3Hash = EncryptionUtil.getSha3Hash(strCert);
    boolean login = deviceSessionCtx.login(new DeviceX509Credentials(sha3Hash));

    if (login) {
      MemoryMetaPool.registerClienId(clientIdentifier, ctx.channel());
      ctx.writeAndFlush(createMqttConnAckMsg(CONNECTION_ACCEPTED));
      connected = true;
      checkGatewaySession();
    } else {
      ctx.writeAndFlush(createMqttConnAckMsg(CONNECTION_REFUSED_NOT_AUTHORIZED));
      ctx.close();
    }
  } catch (Exception e) {
    ctx.writeAndFlush(createMqttConnAckMsg(CONNECTION_REFUSED_NOT_AUTHORIZED));
    ctx.close();
  }
}
 
開發者ID:osswangxining,項目名稱:iothub,代碼行數:21,代碼來源:MqttTransportHandler.java

示例3: getPeerCertificateChain

import javax.security.cert.X509Certificate; //導入依賴的package包/類
public Object[] getPeerCertificateChain(boolean force)
       throws IOException {
       // Look up the current SSLSession
       if (session == null)
           return null;

       // Convert JSSE's certificate format to the ones we need
X509Certificate [] jsseCerts = null;
try {
    jsseCerts = session.getPeerCertificateChain();
} catch(Exception bex) {
    // ignore.
}
if (jsseCerts == null)
    jsseCerts = new X509Certificate[0];
if(jsseCerts.length <= 0 && force) {
    session.invalidate();
    handShake();
    session = ssl.getSession();
}
       return getX509Certificates(session);
   }
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:23,代碼來源:JSSESupport.java

示例4: getPeerCertificateChain

import javax.security.cert.X509Certificate; //導入依賴的package包/類
@Override
public X509Certificate[] getPeerCertificateChain() throws SSLPeerUnverifiedException, RenegotiationRequiredException {
    try {
        return channel.getSslSession().getPeerCertificateChain();
    } catch (SSLPeerUnverifiedException e) {
        try {
            SslClientAuthMode sslClientAuthMode = channel.getOption(Options.SSL_CLIENT_AUTH_MODE);
            if (sslClientAuthMode == SslClientAuthMode.NOT_REQUESTED) {
                throw new RenegotiationRequiredException();
            }
        } catch (IOException e1) {
            //ignore, will not actually happen
        }
        throw e;
    }
}
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:17,代碼來源:SpdySslSessionInfo.java

示例5: BasicSSLSessionInfo

import javax.security.cert.X509Certificate; //導入依賴的package包/類
/**
 *
 * @param sessionId The SSL session ID
 * @param cypherSuite The cypher suite name
 * @param certificate A string representation of the client certificate
 * @throws java.security.cert.CertificateException If the client cert could not be decoded
 * @throws CertificateException If the client cert could not be decoded
 */
public BasicSSLSessionInfo(byte[] sessionId, String cypherSuite, String certificate) throws java.security.cert.CertificateException, CertificateException {
    this.sessionId = sessionId;
    this.cypherSuite = cypherSuite;

    if (certificate != null) {
        java.security.cert.CertificateFactory cf = java.security.cert.CertificateFactory.getInstance("X.509");
        byte[] certificateBytes = certificate.getBytes(US_ASCII);
        ByteArrayInputStream stream = new ByteArrayInputStream(certificateBytes);
        peerCertificate = cf.generateCertificate(stream);
        this.certificate = X509Certificate.getInstance(certificateBytes);
    } else {
        this.peerCertificate = null;
        this.certificate = null;
    }
}
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:24,代碼來源:BasicSSLSessionInfo.java

示例6: toPem

import javax.security.cert.X509Certificate; //導入依賴的package包/類
public static String toPem(final X509Certificate certificate) throws CertificateEncodingException {
    final StringBuilder builder = new StringBuilder();
    builder.append(BEGIN_CERT);
    builder.append('\n');
    builder.append(FlexBase64.encodeString(certificate.getEncoded(), true));
    builder.append('\n');
    builder.append(END_CERT);
    return builder.toString();
}
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:10,代碼來源:Certificates.java

示例7: getPeerCertificateChain

import javax.security.cert.X509Certificate; //導入依賴的package包/類
@Override
public Object[] getPeerCertificateChain(boolean force) throws IOException {
	// Look up the current SSLSession
	if (session == null)
		return null;

	// Convert JSSE's certificate format to the ones we need
	X509Certificate[] jsseCerts = null;
	try {
		jsseCerts = session.getPeerCertificateChain();
	} catch (Exception bex) {
		// ignore.
	}
	if (jsseCerts == null)
		jsseCerts = new X509Certificate[0];
	if (jsseCerts.length <= 0 && force && ssl != null) {
		session.invalidate();
		handShake();
		session = ssl.getSession();
	}
	return getX509Certificates(session);
}
 
開發者ID:how2j,項目名稱:lazycat,代碼行數:23,代碼來源:JSSESupport.java

示例8: processX509CertConnect

import javax.security.cert.X509Certificate; //導入依賴的package包/類
private void processX509CertConnect(ChannelHandlerContext ctx, X509Certificate cert) {
    try {
        String strCert = SslUtil.getX509CertificateString(cert);
        String sha3Hash = EncryptionUtil.getSha3Hash(strCert);
        if (deviceSessionCtx.login(new DeviceX509Credentials(sha3Hash))) {
            ctx.writeAndFlush(createMqttConnAckMsg(CONNECTION_ACCEPTED));
            connected = true;
            checkGatewaySession();
        } else {
            ctx.writeAndFlush(createMqttConnAckMsg(CONNECTION_REFUSED_NOT_AUTHORIZED));
            ctx.close();
        }
    } catch (Exception e) {
        ctx.writeAndFlush(createMqttConnAckMsg(CONNECTION_REFUSED_NOT_AUTHORIZED));
        ctx.close();
    }
}
 
開發者ID:thingsboard,項目名稱:thingsboard,代碼行數:18,代碼來源:MqttTransportHandler.java

示例9: populateUserAndRolesFromCert

import javax.security.cert.X509Certificate; //導入依賴的package包/類
private boolean populateUserAndRolesFromCert(X509Certificate certificate) throws InvalidNameException {
    LdapName ldapName = new LdapName(certificate.getSubjectDN().getName());

    // Find the first CN that maps to a valid user as supplied in the config
    Optional<String> validCN = ldapName.getRdns().stream()
        .filter(rdn -> rdn.getType().equalsIgnoreCase("CN"))
        .map(rdn -> String.valueOf(rdn.getValue()))
        .filter(n -> validCertUsers.containsKey(n)).findFirst();

    if(validCN.isPresent()) {
        String name = validCN.get();
        user = name; roles.addAll(validCertUsers.get(name));
        return true;
    } else {
        return false;
    }
}
 
開發者ID:EnMasseProject,項目名稱:enmasse,代碼行數:18,代碼來源:SaslDelegatingLogin.java

示例10: enrichWithClientCertInformation

import javax.security.cert.X509Certificate; //導入依賴的package包/類
/**
 * Enriches the message with client certificate details such as subject name, serial number etc.
 * <p/>
 * If the certificate is unverified then the headers is not enriched.
 *
 * @param sslSession  the SSL session
 * @param message     the message to enrich
 */
protected void enrichWithClientCertInformation(SSLSession sslSession, Message message) {
    try {
        X509Certificate[] certificates = sslSession.getPeerCertificateChain();
        if (certificates != null && certificates.length > 0) {
            X509Certificate cert = certificates[0];

            Principal subject = cert.getSubjectDN();
            if (subject != null) {
                message.setHeader(NettyConstants.NETTY_SSL_CLIENT_CERT_SUBJECT_NAME, subject.getName());
            }
            Principal issuer = cert.getIssuerDN();
            if (issuer != null) {
                message.setHeader(NettyConstants.NETTY_SSL_CLIENT_CERT_ISSUER_NAME, issuer.getName());
            }
            BigInteger serial = cert.getSerialNumber();
            if (serial != null) {
                message.setHeader(NettyConstants.NETTY_SSL_CLIENT_CERT_SERIAL_NO, serial.toString());
            }
            message.setHeader(NettyConstants.NETTY_SSL_CLIENT_CERT_NOT_BEFORE, cert.getNotBefore());
            message.setHeader(NettyConstants.NETTY_SSL_CLIENT_CERT_NOT_AFTER, cert.getNotAfter());
        }
    } catch (SSLPeerUnverifiedException e) {
        // ignore
    }
}
 
開發者ID:HydAu,項目名稱:Camel,代碼行數:34,代碼來源:NettyEndpoint.java

示例11: testHandleSuccessRequestMutualAuthHeader

import javax.security.cert.X509Certificate; //導入依賴的package包/類
@Test(description = "Handle request with device type URI with Mutual Auth Header",
        dependsOnMethods = "testHandleSuccessRequestProxyMutualAuthHeader")
public void testHandleSuccessRequestMutualAuthHeader() throws Exception {
    HashMap<String, String> transportHeaders = new HashMap<>();
    transportHeaders.put(AuthConstants.MUTUAL_AUTH_HEADER, "Test Header");
    setMockClient();
    this.mockClient.setResponse(getAccessTokenReponse());
    this.mockClient.setResponse(getValidationResponse());
    MessageContext messageContext = createSynapseMessageContext("<empty/>", this.synapseConfiguration,
            transportHeaders, "https://test.com/testservice/api/testdevice");
    org.apache.axis2.context.MessageContext axisMC = ((Axis2MessageContext) messageContext).getAxis2MessageContext();
    String certStr = getContent(TestUtils.getAbsolutePathOfConfig("ra_cert.pem"));
    X509Certificate cert = X509Certificate.getInstance(new ByteArrayInputStream(certStr.
            getBytes(StandardCharsets.UTF_8.name())));
    axisMC.setProperty(AuthConstants.CLIENT_CERTIFICATE, new X509Certificate[]{cert});
    boolean response = this.handler.handleRequest(messageContext);
    Assert.assertTrue(response);
    this.mockClient.reset();
}
 
開發者ID:wso2,項目名稱:carbon-device-mgt,代碼行數:20,代碼來源:AuthenticationHandlerTest.java

示例12: checkCertificates

import javax.security.cert.X509Certificate; //導入依賴的package包/類
/**
 * Checks whether any active users' certificates are beyond the expiration threshold.
 */
@TransactionAttribute
public void checkCertificates() {

    List<UserAuthentication> auths = userAuthDao.findAll();

    Calendar cal = Calendar.getInstance();
    cal.add(Calendar.DATE, configuration.getCertificateCheckThreshold());
    Date cutoff = cal.getTime();

    for (UserAuthentication auth : auths) {
        if (auth.getActive() && auth.getCertificate() != null) {
            try {
                X509Certificate certificate = X509Certificate
                        .getInstance(Base64.decodeBase64(auth.getCertificate()));
                if (cutoff.after(certificate.getNotAfter())) {
                    notifyExpirationCheckFail(auth.getUser().getUsername());
                }
            } catch (CertificateException e) {
                logger.warn("Certificate could not be read", e);
            }
        }
    }
}
 
開發者ID:psnc-dl,項目名稱:darceo,代碼行數:27,代碼來源:CertificateChecker.java

示例13: getPeerCertificateChain

import javax.security.cert.X509Certificate; //導入依賴的package包/類
@Override
public X509Certificate[] getPeerCertificateChain() throws SSLPeerUnverifiedException {
    // these are lazy created to reduce memory overhead
    X509Certificate[] c = x509PeerCerts;
    if (c == null) {
        if (SSL.isInInit(ssl) != 0) {
            throw new SSLPeerUnverifiedException("peer not verified");
        }
        byte[][] chain = SSL.getPeerCertChain(ssl);
        if (chain == null) {
            throw new SSLPeerUnverifiedException("peer not verified");
        }
        X509Certificate[] peerCerts = new X509Certificate[chain.length];
        for (int i = 0; i < peerCerts.length; i++) {
            try {
                peerCerts[i] = X509Certificate.getInstance(chain[i]);
            } catch (CertificateException e) {
                throw new IllegalStateException(e);
            }
        }
        c = x509PeerCerts = peerCerts;
    }
    return c;
}
 
開發者ID:wuyinxian124,項目名稱:netty4.0.27Learn,代碼行數:25,代碼來源:OpenSslEngine.java

示例14: parse

import javax.security.cert.X509Certificate; //導入依賴的package包/類
public CertificateMeta parse() throws IOException, CertificateException {
  X509Certificate certificate = X509Certificate.getInstance(Utils.toByteArray(in));
  CertificateMeta.Builder builder = CertificateMeta.newCertificateMeta();
  byte[] bytes = certificate.getEncoded();
  String certMd5 = md5Digest(bytes);
  String publicKeyString = byteToHexString(bytes);
  String certBase64Md5 = md5Digest(publicKeyString);
  builder.data(bytes);
  builder.certBase64Md5(certBase64Md5);
  builder.certMd5(certMd5);
  builder.startDate(certificate.getNotBefore());
  builder.endDate(certificate.getNotAfter());
  builder.signAlgorithm(certificate.getSigAlgName());
  builder.signAlgorithmOID(certificate.getSigAlgOID());
  return builder.build();
}
 
開發者ID:jaredrummler,項目名稱:APKParser,代碼行數:17,代碼來源:CertificateParser.java

示例15: getJaasCertificateCallbackHandler

import javax.security.cert.X509Certificate; //導入依賴的package包/類
private JaasCallbackHandler getJaasCertificateCallbackHandler(String user) {
   JMXPrincipal principal = new JMXPrincipal(user);
   X509Certificate cert = new StubX509Certificate(principal);
   return new JaasCallbackHandler(null, null, null) {
      @Override
      public void handle(Callback[] callbacks) throws IOException, UnsupportedCallbackException {
         for (Callback callback : callbacks) {
            if (callback instanceof CertificateCallback) {
               CertificateCallback certCallback = (CertificateCallback) callback;
               certCallback.setCertificates(new X509Certificate[]{cert});
            } else {
               throw new UnsupportedCallbackException(callback);
            }
         }
      }
   };
}
 
開發者ID:apache,項目名稱:activemq-artemis,代碼行數:18,代碼來源:TextFileCertificateLoginModuleTest.java


注:本文中的javax.security.cert.X509Certificate類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。