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


Java SSLException類代碼示例

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


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

示例1: connectionsAreNotReusedIfSslSocketFactoryChanges

import javax.net.ssl.SSLException; //導入依賴的package包/類
@Test public void connectionsAreNotReusedIfSslSocketFactoryChanges() throws Exception {
  enableHttps();
  server.enqueue(new MockResponse());
  server.enqueue(new MockResponse());

  Request request = new Request.Builder()
      .url(server.url("/"))
      .build();

  Response response = client.newCall(request).execute();
  response.body().close();

  // This client shares a connection pool but has a different SSL socket factory.
  SslClient sslClient2 = new SslClient.Builder().build();
  OkHttpClient anotherClient = client.newBuilder()
      .sslSocketFactory(sslClient2.socketFactory, sslClient2.trustManager)
      .build();

  // This client fails to connect because the new SSL socket factory refuses.
  try {
    anotherClient.newCall(request).execute();
    fail();
  } catch (SSLException expected) {
  }
}
 
開發者ID:weiwenqiang,項目名稱:GitHub,代碼行數:26,代碼來源:ConnectionReuseTest.java

示例2: CertStatusReqItemV2

import javax.net.ssl.SSLException; //導入依賴的package包/類
/**
 * Construct a {@code CertStatusReqItemV2} object from encoded bytes
 *
 * @param requestBytes the encoded bytes for the {@code CertStatusReqItemV2}
 *
 * @throws IOException if any decoding errors take place
 * @throws IllegalArgumentException if the parsed reqType value is not a
 *      supported status request type.
 */
CertStatusReqItemV2(byte[] reqItemBytes) throws IOException {
    ByteBuffer reqBuf = ByteBuffer.wrap(reqItemBytes);
    statReqType = StatusRequestType.get(reqBuf.get());
    int requestLength = Short.toUnsignedInt(reqBuf.getShort());

    if (requestLength == reqBuf.remaining()) {
        byte[] statReqBytes = new byte[requestLength];
        reqBuf.get(statReqBytes);
        if (statReqType == StatusRequestType.OCSP ||
                statReqType == StatusRequestType.OCSP_MULTI) {
            request = new OCSPStatusRequest(statReqBytes);
        } else {
            request = new UnknownStatusRequest(statReqBytes);
        }
    } else {
        throw new SSLException("Incorrect request_length: " +
                "Expected " + reqBuf.remaining() + ", got " +
                requestLength);
    }
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:30,代碼來源:CertStatusReqItemV2.java

示例3: buildSslCtx

import javax.net.ssl.SSLException; //導入依賴的package包/類
private SslContext buildSslCtx() {
  SslProvider provider = OpenSsl.isAlpnSupported() ? SslProvider.OPENSSL : SslProvider.JDK;
  try {
    return SslContextBuilder.forClient()
        .sslProvider(provider)
        .ciphers(Http2SecurityUtil.CIPHERS, SupportedCipherSuiteFilter.INSTANCE)
        .trustManager(InsecureTrustManagerFactory.INSTANCE)
        // TODO(JR): Make a seperate Handler Class for http2 as opposed to autoneg
        //        .applicationProtocolConfig(new ApplicationProtocolConfig(
        //          ApplicationProtocolConfig.Protocol.ALPN,
        //          // NO_ADVERTISE is currently the only mode supported by both OpenSsl and JDK providers.
        //          ApplicationProtocolConfig.SelectorFailureBehavior.NO_ADVERTISE,
        //          // ACCEPT is currently the only mode supported by both OpenSsl and JDK providers.
        //          ApplicationProtocolConfig.SelectedListenerFailureBehavior.ACCEPT,
        //          ApplicationProtocolNames.HTTP_2,
        //          ApplicationProtocolNames.HTTP_1_1))
        .build();
  } catch (SSLException e) {
    e.printStackTrace();
  }

  return null;
}
 
開發者ID:Nordstrom,項目名稱:xrpc,代碼行數:24,代碼來源:XrpcClient.java

示例4: execPROT

import javax.net.ssl.SSLException; //導入依賴的package包/類
/**
 * PROT command.
 * <ul>
 * <li>C - Clear</li>
 * <li>S - Safe(SSL protocol only)</li>
 * <li>E - Confidential(SSL protocol only)</li>
 * <li>P - Private</li>
 * </ul>
 * <b>N.B.</b> the method calls
 *  {@link #setSocketFactory(javax.net.SocketFactory)} and
 *  {@link #setServerSocketFactory(javax.net.ServerSocketFactory)}
 *
 * @param prot Data Channel Protection Level, if {@code null}, use {@link #DEFAULT_PROT}.
 * @throws javax.net.ssl.SSLException If the server reply code does not equal  {@code 200}.
 * @throws java.io.IOException If an I/O error occurs while sending
 * the command.
 */
public void execPROT(String prot) throws SSLException, IOException {
    if (prot == null) {
        prot = DEFAULT_PROT;
    }
    if (!checkPROTValue(prot)) {
        throw new IllegalArgumentException();
    }
    if (FTPReply.COMMAND_OK != sendCommand(CMD_PROT, prot)) {
        throw new SSLException(getReplyString());
    }
    if (DEFAULT_PROT.equals(prot)) {
        setSocketFactory(null);
        setServerSocketFactory(null);
    } else {
        setSocketFactory(new FTPSSocketFactory(context));
        setServerSocketFactory(new FTPSServerSocketFactory(context));
        initSslContext();
    }
}
 
開發者ID:archos-sa,項目名稱:aos-FileCoreLibrary,代碼行數:37,代碼來源:FTPSClient.java

示例5: sendCommand

import javax.net.ssl.SSLException; //導入依賴的package包/類
/**
 * Send an FTP command.
 * A successful CCC (Clear Command Channel) command causes the underlying {@link javax.net.ssl.SSLSocket}
 * instance to be assigned to a plain {@link java.net.Socket}
 * @param command The FTP command.
 * @return server reply.
 * @throws java.io.IOException If an I/O error occurs while sending the command.
 * @throws javax.net.ssl.SSLException if a CCC command fails
 * @see FTP#sendCommand(String)
 */
// Would like to remove this method, but that will break any existing clients that are using CCC
@Override
public int sendCommand(String command, String args) throws IOException {
    int repCode = super.sendCommand(command, args);
    /* If CCC is issued, restore socket i/o streams to unsecured versions */
    if (CMD_CCC.equals(command)) {
        if (FTPReply.COMMAND_OK == repCode) {
            _socket_.close();
            _socket_ = plainSocket;
            _controlInput_ = new BufferedReader(
                new InputStreamReader(
                    _socket_ .getInputStream(), getControlEncoding()));
            _controlOutput_ = new BufferedWriter(
                new OutputStreamWriter(
                    _socket_.getOutputStream(), getControlEncoding()));
        } else {
            throw new SSLException(getReplyString());
        }
    }
    return repCode;
}
 
開發者ID:archos-sa,項目名稱:aos-FileCoreLibrary,代碼行數:32,代碼來源:FTPSClient.java

示例6: startSsl

import javax.net.ssl.SSLException; //導入依賴的package包/類
/**
 * (Re)starts SSL session for the specified <tt>session</tt> if not started yet.
 * Please note that SSL session is automatically started by default, and therefore
 * you don't need to call this method unless you've used TLS closure.
 *
 * @return <tt>true</tt> if the SSL session has been started, <tt>false</tt> if already started.
 * @throws SSLException if failed to start the SSL session
 */
public boolean startSsl(IoSession session) throws SSLException {
    SslHandler handler = getSslSessionHandler(session);
    boolean started;
    synchronized (handler) {
        if (handler.isOutboundDone()) {
            NextFilter nextFilter = (NextFilter) session.getAttribute(NEXT_FILTER);
            handler.destroy();
            handler.init();
            handler.handshake(nextFilter);
            started = true;
        } else {
            started = false;
        }
    }

    handler.flushScheduledEvents();
    return started;
}
 
開發者ID:eclipse,項目名稱:neoscada,代碼行數:27,代碼來源:SslFilter.java

示例7: onPreAdd

import javax.net.ssl.SSLException; //導入依賴的package包/類
/**
 * Executed just before the filter is added into the chain, we do :
 * <ul>
 * <li>check that we don't have a SSL filter already present
 * <li>we update the next filter
 * <li>we create the SSL handler helper class
 * <li>and we store it into the session's Attributes
 * </ul>
 */
@Override
public void onPreAdd(IoFilterChain parent, String name, NextFilter nextFilter) throws SSLException {
    // Check that we don't have a SSL filter already present in the chain
    if (parent.contains(SslFilter.class)) {
        String msg = "Only one SSL filter is permitted in a chain.";
        LOGGER.error(msg);
        throw new IllegalStateException(msg);
    }

    LOGGER.debug("Adding the SSL Filter {} to the chain", name);

    IoSession session = parent.getSession();
    session.setAttribute(NEXT_FILTER, nextFilter);

    // Create a SSL handler and start handshake.
    SslHandler handler = new SslHandler(this, session);
    handler.init();
    session.setAttribute(SSL_HANDLER, handler);
}
 
開發者ID:eclipse,項目名稱:neoscada,代碼行數:29,代碼來源:SslFilter.java

示例8: retryRequest

import javax.net.ssl.SSLException; //導入依賴的package包/類
@Override
public boolean retryRequest(IOException exception, int executionCount, HttpContext context) {

    if (executionCount >= 3) {// 如果已經重試了3次,就放棄
        return false;
    }

    if (exception instanceof NoHttpResponseException) {// 如果服務器丟掉了連接,那麽就重試
        return true;
    }

    if (exception instanceof SSLHandshakeException) {// 不要重試SSL握手異常
        return false;
    }

    if (exception instanceof InterruptedIOException) {// 超時
        return true;
    }

    if (exception instanceof UnknownHostException) {// 目標服務器不可達
        return false;
    }

    if (exception instanceof ConnectTimeoutException) {// 連接被拒絕
        return false;
    }

    if (exception instanceof SSLException) {// ssl握手異常
        return false;
    }

    HttpClientContext clientContext = HttpClientContext.adapt(context);
    HttpRequest request = clientContext.getRequest();

    // 如果請求是冪等的,就再次嘗試
    if (!(request instanceof HttpEntityEnclosingRequest)) {
        return true;
    }
    return false;
}
 
開發者ID:fengzhizi715,項目名稱:ProxyPool,代碼行數:41,代碼來源:RetryHandler.java

示例9: handleSslException

import javax.net.ssl.SSLException; //導入依賴的package包/類
private void handleSslException(SSLException e) throws CertificateValidationException, SSLException {
    if (e.getCause() instanceof CertificateException) {
        throw new CertificateValidationException(e.getMessage(), e);
    } else {
        throw e;
    }
}
 
開發者ID:philipwhiuk,項目名稱:q-mail,代碼行數:8,代碼來源:ImapConnection.java

示例10: unwrap

import javax.net.ssl.SSLException; //導入依賴的package包/類
/**
   * performs the unwrap operation by unwrapping from {@link #inCrypt} to
   * {@link #inData}
*
   */
  private synchronized ByteBuffer unwrap() throws SSLException {
      int rem;
      do {
          rem = inData.remaining();
          readEngineResult = sslEngine.unwrap(inCrypt, inData);
      } while (readEngineResult.getStatus() == SSLEngineResult.Status.OK && (rem != inData.remaining() || sslEngine.getHandshakeStatus() == HandshakeStatus.NEED_UNWRAP));
      inData.flip();
      return inData;
  }
 
開發者ID:GloriousEggroll,項目名稱:quorrabot,代碼行數:15,代碼來源:SSLSocketChannel2.java

示例11: whenTrustedSocketFactoryThrowsCertificateException_throwMessagingException

import javax.net.ssl.SSLException; //導入依賴的package包/類
@Test(expected = MessagingException.class)
public void whenTrustedSocketFactoryThrowsCertificateException_throwMessagingException() throws Exception {
    when(mockTrustedSocketFactory.createSocket(null, "server", 12345, null)).thenThrow(
            new SSLException(""));

    setSettingsForMockSocket();
    settings.setAuthType(AuthType.PLAIN);

    new Pop3Connection(settings, mockTrustedSocketFactory);
}
 
開發者ID:philipwhiuk,項目名稱:q-mail,代碼行數:11,代碼來源:Pop3ConnectionTest.java

示例12: verify

import javax.net.ssl.SSLException; //導入依賴的package包/類
@Override
public boolean verify(String host, SSLSession session) {
  try {
    Certificate[] certificates = session.getPeerCertificates();
    return verify(host, (X509Certificate) certificates[0]);
  } catch (SSLException e) {
    return false;
  }
}
 
開發者ID:weiwenqiang,項目名稱:GitHub,代碼行數:10,代碼來源:OkHostnameVerifier.java

示例13: shouldRetry

import javax.net.ssl.SSLException; //導入依賴的package包/類
public boolean shouldRetry(Exception e, int currentRetryCount) {
    if (currentRetryCount >= maxRetryCount) {
        return false;
    }
    if (e instanceof ClientException) {
        if (((ClientException) e).isCanceledException()) {
            return false;
        }

        Exception localException = (Exception) e.getCause();
        if (localException instanceof InterruptedIOException
            && !(localException instanceof SocketTimeoutException)) {
            WCSLogUtil.e("[shouldRetry] - is interrupted!");
            return false;
        } else if (localException instanceof IllegalArgumentException) {
            return false;
        } else if (localException instanceof SSLException) {
            return false;
        }
        WCSLogUtil.d("shouldRetry - " + e.toString());
        e.getCause().printStackTrace();
        return true;
    } else if (e instanceof ServiceException) {
        ServiceException serviceException = (ServiceException) e;
        if (serviceException.getStatusCode() == 408 || (serviceException.getStatusCode() >= 500 &&
            serviceException.getStatusCode() != 579)) {
            return true;
        } else {
            return false;
        }
    } else {
        return false;
    }
}
 
開發者ID:Wangsu-Cloud-Storage,項目名稱:wcs-android-sdk,代碼行數:35,代碼來源:WcsRetryHandler.java

示例14: buildServerSslContext

import javax.net.ssl.SSLException; //導入依賴的package包/類
private SslContext buildServerSslContext() {
  try {
    InputStream certs = SslUtil.loadInputStreamCert("server.pem");
    InputStream keys = SslUtil.loadInputStreamCert("server_pkcs8.key");
    return GrpcSslContexts.configure(SslContextBuilder.forServer(certs, keys)).build();
  } catch (SSLException e) {
    throw new RpcFrameworkException(e);
  }
}
 
開發者ID:venus-boot,項目名稱:saluki,代碼行數:10,代碼來源:GrpcEngine.java

示例15: CipherSuiteList

import javax.net.ssl.SSLException; //導入依賴的package包/類
/**
 * Read a CipherSuiteList from a HandshakeInStream in V3 ClientHello
 * format. Does not check if the listed ciphersuites are known or
 * supported.
 */
CipherSuiteList(HandshakeInStream in) throws IOException {
    byte[] bytes = in.getBytes16();
    if ((bytes.length & 1) != 0) {
        throw new SSLException("Invalid ClientHello message");
    }
    cipherSuites = new ArrayList<CipherSuite>(bytes.length >> 1);
    for (int i = 0; i < bytes.length; i += 2) {
        cipherSuites.add(CipherSuite.valueOf(bytes[i], bytes[i+1]));
    }
}
 
開發者ID:SunburstApps,項目名稱:OpenJSharp,代碼行數:16,代碼來源:CipherSuiteList.java


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