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


Java SSLHandshakeException.getCause方法代碼示例

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


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

示例1: testOr

import javax.net.ssl.SSLHandshakeException; //導入方法依賴的package包/類
@Test
public void testOr() throws Exception {
  MemorizingTrustManager memo=new MemorizingTrustManager.Builder()
    .saveTo(memoDir, "sekrit".toCharArray())
    .noTOFU()
    .build();

  final TrustManagerBuilder tmb=new TrustManagerBuilder()
    .withConfig(InstrumentationRegistry.getContext(),
      R.xml.okhttp3_selfsigned_debug, false)
    .or()
    .add(memo);

  OkHttp3Integrator.applyTo(tmb, builder);
  OkHttpClient client=builder.build();
  CertificateNotMemorizedException memoEx;

  try {
    client.newCall(buildRequest()).execute();

    throw new AssertionFailedError("Expected SSLHandshakeException, did not get!");
  }
  catch (SSLHandshakeException e) {
    if (e.getCause() instanceof CertificateNotMemorizedException) {
      memoEx=(CertificateNotMemorizedException)e.getCause();
    }
    else {
      throw new AssertionFailedError("Expected CertificateNotMemorizedException, did not get!");
    }
  }

  memo.memorize(memoEx);

  Response response=client.newCall(buildRequest()).execute();
  Assert.assertEquals(getExpectedResponse(), response.body().string());
}
 
開發者ID:commonsguy,項目名稱:cwac-netsecurity,代碼行數:37,代碼來源:OkHttp3MemorizationTests.java

示例2: testAnd

import javax.net.ssl.SSLHandshakeException; //導入方法依賴的package包/類
@Test
public void testAnd() throws Exception {
  MemorizingTrustManager memo=new MemorizingTrustManager.Builder()
    .saveTo(memoDir, "sekrit".toCharArray())
    .noTOFU()
    .build();

  final TrustManagerBuilder tmb=new TrustManagerBuilder()
    .withConfig(InstrumentationRegistry.getContext(),
      R.xml.okhttp3_selfsigned_debug, true)
    .and()
    .add(memo);

  OkHttp3Integrator.applyTo(tmb, builder);
  OkHttpClient client=builder.build();
  CertificateNotMemorizedException memoEx;

  try {
    client.newCall(buildRequest()).execute();

    throw new AssertionFailedError("Expected SSLHandshakeException, did not get!");
  }
  catch (SSLHandshakeException e) {
    if (e.getCause() instanceof CertificateNotMemorizedException) {
      memoEx=(CertificateNotMemorizedException)e.getCause();
    }
    else {
      throw new AssertionFailedError("Expected CertificateNotMemorizedException, did not get!");
    }
  }

  memo.memorize(memoEx);

  Response response=client.newCall(buildRequest()).execute();
  Assert.assertEquals(getExpectedResponse(), response.body().string());
}
 
開發者ID:commonsguy,項目名稱:cwac-netsecurity,代碼行數:37,代碼來源:OkHttp3MemorizationTests.java

示例3: testSingleItemPrivate

import javax.net.ssl.SSLHandshakeException; //導入方法依賴的package包/類
@Test
public void testSingleItemPrivate() throws Exception {
  MemorizingTrustManager memo=new MemorizingTrustManager.Builder()
    .saveTo(memoDir, "sekrit".toCharArray())
    .noTOFU()
    .onlySingleItemChains()
    .build();

  final TrustManagerBuilder tmb=new TrustManagerBuilder()
    .withConfig(InstrumentationRegistry.getContext(),
      R.xml.okhttp3_selfsigned_debug, true)
    .and()
    .add(memo);

  OkHttp3Integrator.applyTo(tmb, builder);
  OkHttpClient client=builder.build();
  CertificateNotMemorizedException memoEx;

  try {
    client.newCall(buildRequest()).execute();

    throw new AssertionFailedError("Expected SSLHandshakeException, did not get!");
  }
  catch (SSLHandshakeException e) {
    if (e.getCause() instanceof CertificateNotMemorizedException) {
      memoEx=(CertificateNotMemorizedException)e.getCause();
    }
    else {
      throw new AssertionFailedError("Expected CertificateNotMemorizedException, did not get!");
    }
  }

  memo.memorize(memoEx);

  Response response=client.newCall(buildRequest()).execute();
  Assert.assertEquals(getExpectedResponse(), response.body().string());
}
 
開發者ID:commonsguy,項目名稱:cwac-netsecurity,代碼行數:38,代碼來源:OkHttp3MemorizationTests.java

示例4: testPinnedDomainExpiredChain

import javax.net.ssl.SSLHandshakeException; //導入方法依賴的package包/類
@Test
public void testPinnedDomainExpiredChain() throws IOException {
    // Initialize TrustKit
    String serverHostname = "expired.badssl.com";
    TestableTrustKit.initializeWithNetworkSecurityConfiguration(
            InstrumentationRegistry.getContext(), mockReporter);

    // Create a TrustKit SocketFactory and ensure the connection fails
    SSLSocketFactory test = TestableTrustKit.getInstance().getSSLSocketFactory(serverHostname);
    boolean didReceiveHandshakeError = false;
    try {
        test.createSocket(serverHostname, 443).getInputStream();
    } catch (SSLHandshakeException e) {
        if ((e.getCause() instanceof CertificateException
                && !(e.getCause().getMessage().startsWith("Pin verification failed")))) {
            didReceiveHandshakeError = true;
        }
    }
    assertTrue(didReceiveHandshakeError);

    if (Build.VERSION.SDK_INT < 17) {
        // TrustKit does not do anything for API level < 17 hence there is no reporting
        return;
    }

    // Ensure the background reporter was called
    verify(mockReporter).pinValidationFailed(
            eq(serverHostname),
            eq(0),
            (List<X509Certificate>) org.mockito.Matchers.isNotNull(),
            (List<X509Certificate>) org.mockito.Matchers.isNotNull(),
            eq(TestableTrustKit.getInstance().getConfiguration().getPolicyForHostname(serverHostname)),
            eq(PinningValidationResult.FAILED_CERTIFICATE_CHAIN_NOT_TRUSTED)
    );
}
 
開發者ID:datatheorem,項目名稱:TrustKit-Android,代碼行數:36,代碼來源:SSLSocketFactoryTest.java

示例5: testPinnedDomainWrongHostnameChain

import javax.net.ssl.SSLHandshakeException; //導入方法依賴的package包/類
@Test
public void testPinnedDomainWrongHostnameChain() throws IOException {
    // Initialize TrustKit
    String serverHostname = "wrong.host.badssl.com";
    TestableTrustKit.initializeWithNetworkSecurityConfiguration(
            InstrumentationRegistry.getContext(), mockReporter);

    // Create a TrustKit SocketFactory and ensure the connection fails
    SSLSocketFactory test = TestableTrustKit.getInstance().getSSLSocketFactory(serverHostname);
    boolean didReceiveHandshakeError = false;
    try {
        test.createSocket(serverHostname, 443).getInputStream();
    } catch (SSLHandshakeException e) {
        if ((e.getCause() instanceof CertificateException
                && !(e.getCause().getMessage().startsWith("Pin verification failed")))) {
            didReceiveHandshakeError = true;
        }
    }
    assertTrue(didReceiveHandshakeError);

    if (Build.VERSION.SDK_INT < 17) {
        // TrustKit does not do anything for API level < 17 hence there is no reporting
        return;
    }

    // Ensure the background reporter was called
    verify(mockReporter).pinValidationFailed(
            eq(serverHostname),
            eq(0),
            (List<X509Certificate>) org.mockito.Matchers.isNotNull(),
            (List<X509Certificate>) org.mockito.Matchers.isNotNull(),
            eq(TestableTrustKit.getInstance().getConfiguration().getPolicyForHostname(serverHostname)),
            eq(PinningValidationResult.FAILED_CERTIFICATE_CHAIN_NOT_TRUSTED)
    );
}
 
開發者ID:datatheorem,項目名稱:TrustKit-Android,代碼行數:36,代碼來源:SSLSocketFactoryTest.java

示例6: testPinnedDomainInvalidPin

import javax.net.ssl.SSLHandshakeException; //導入方法依賴的package包/類
@Test
public void testPinnedDomainInvalidPin() throws IOException {
    if (Build.VERSION.SDK_INT < 17) {
        // TrustKit does not do anything for API level < 17 hence the connection will succeed
        return;
    }

    String serverHostname = "www.yahoo.com";
    TestableTrustKit.initializeWithNetworkSecurityConfiguration(
            InstrumentationRegistry.getContext(), mockReporter);

    // Create a TrustKit SocketFactory and ensure the connection fails
    SSLSocketFactory test = TestableTrustKit.getInstance().getSSLSocketFactory(serverHostname);
    boolean didReceivePinningError = false;
    try {
        test.createSocket(serverHostname, 443).getInputStream();
    } catch (SSLHandshakeException e) {
        if ((e.getCause() instanceof CertificateException
                && (e.getCause().getMessage().startsWith("Pin verification failed")))) {
            didReceivePinningError = true;
        }
    }
    assertTrue(didReceivePinningError);

    // Ensure the background reporter was called
    verify(mockReporter).pinValidationFailed(
            eq(serverHostname),
            eq(0),
            (List<X509Certificate>) org.mockito.Matchers.isNotNull(),
            (List<X509Certificate>) org.mockito.Matchers.isNotNull(),
            eq(TestableTrustKit.getInstance().getConfiguration().getPolicyForHostname(serverHostname)),
            eq(PinningValidationResult.FAILED)
    );
}
 
開發者ID:datatheorem,項目名稱:TrustKit-Android,代碼行數:35,代碼來源:SSLSocketFactoryTest.java

示例7: testPinnedDomainUntrustedChainAndPinningNotEnforced

import javax.net.ssl.SSLHandshakeException; //導入方法依賴的package包/類
@Test
public void testPinnedDomainUntrustedChainAndPinningNotEnforced() throws IOException {
    String serverHostname = "untrusted-root.badssl.com";
    TestableTrustKit.initializeWithNetworkSecurityConfiguration(
            InstrumentationRegistry.getContext(), mockReporter);

    // Create a TrustKit SocketFactory and ensure the connection fails
    SSLSocketFactory test = TestableTrustKit.getInstance().getSSLSocketFactory(serverHostname);
    boolean didReceiveHandshakeError = false;
    try {
        test.createSocket(serverHostname, 443).getInputStream();
    } catch (SSLHandshakeException e) {
        if ((e.getCause() instanceof CertificateException
                && !(e.getCause().getMessage().startsWith("Pin verification failed")))) {
            didReceiveHandshakeError = true;
        }
    }

    // Ensure the SSL handshake failed (but not because of a pinning error)
    assertTrue(didReceiveHandshakeError);

    if (Build.VERSION.SDK_INT < 17) {
        // TrustKit does not do anything for API level < 17 hence there is no reporting
        return;
    }

    // Ensure the background reporter was called
    verify(mockReporter).pinValidationFailed(
            eq(serverHostname),
            eq(0),
            (List<X509Certificate>) org.mockito.Matchers.isNotNull(),
            (List<X509Certificate>) org.mockito.Matchers.isNotNull(),
            eq(TestableTrustKit.getInstance().getConfiguration().getPolicyForHostname(serverHostname)),
            eq(PinningValidationResult.FAILED_CERTIFICATE_CHAIN_NOT_TRUSTED)
    );
}
 
開發者ID:datatheorem,項目名稱:TrustKit-Android,代碼行數:37,代碼來源:SSLSocketFactoryTest.java

示例8: testNonPinnedDomainUntrustedRootChain

import javax.net.ssl.SSLHandshakeException; //導入方法依賴的package包/類
@Test
public void testNonPinnedDomainUntrustedRootChain() throws IOException {
    String serverHostname = "www.cacert.org";
    final DomainPinningPolicy domainPolicy = new DomainPinningPolicy.Builder()
            .setHostname("other.domain.com")
            .setShouldEnforcePinning(true)
            .setPublicKeyHashes(new HashSet<String>() {{
                // Wrong pins
                add("AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA=");
                add("BBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBB=");
            }}).build();

    TestableTrustKit.init(new HashSet<DomainPinningPolicy>() {{ add(domainPolicy); }},
            InstrumentationRegistry.getContext(),
            mockReporter);

    // Create a TrustKit SocketFactory and ensure the connection fails
    // This means that TrustKit does not interfere with default certificate validation
    SSLSocketFactory test = TestableTrustKit.getInstance().getSSLSocketFactory(serverHostname);
    boolean didReceiveHandshakeError = false;
    try {
        test.createSocket(serverHostname, 443).getInputStream();
    } catch (SSLHandshakeException e) {
        if ((e.getCause() instanceof CertificateException
                && !(e.getCause().getMessage().startsWith("Pin verification failed")))) {
            didReceiveHandshakeError = true;
        }
    }
    assertTrue(didReceiveHandshakeError);

    // Ensure the background reporter was NOT called as we only want reports for pinned domains
    verify(mockReporter, never()).pinValidationFailed(
            eq(serverHostname),
            eq(0),
            (List<X509Certificate>) org.mockito.Matchers.isNotNull(),
            (List<X509Certificate>) org.mockito.Matchers.isNotNull(),
            eq(TestableTrustKit.getInstance().getConfiguration().getPolicyForHostname(serverHostname)),
            eq(PinningValidationResult.FAILED)
    );
}
 
開發者ID:datatheorem,項目名稱:TrustKit-Android,代碼行數:41,代碼來源:SSLSocketFactoryTest.java

示例9: testTOFU

import javax.net.ssl.SSLHandshakeException; //導入方法依賴的package包/類
@Test
public void testTOFU() throws Exception {
  MemorizingTrustManager memo=new MemorizingTrustManager.Builder()
    .saveTo(memoDir, "sekrit".toCharArray())
    .build();

  final TrustManagerBuilder tmb=new TrustManagerBuilder().add(memo);

  HttpURLConnection c=
    (HttpURLConnection)new URL(getUrl()).openConnection();

  tmb.applyTo(c);

  InputStream in=c.getInputStream();

  try {
    Assert.assertEquals(getExpectedResponse(), AbstractHURLTest.slurp(in));
  }
  finally {
    in.close();
  }

  c=(HttpURLConnection)new URL(getUrl()).openConnection();
  tmb.applyTo(c);
  in=c.getInputStream();

  try {
    Assert.assertEquals(getExpectedResponse(), AbstractHURLTest.slurp(in));
  }
  finally {
    in.close();
  }

  memo.clearAll(true); // clear TOFU before creating non-TOFU trust manager

  memo=new MemorizingTrustManager.Builder()
    .saveTo(memoDir, "sekrit".toCharArray())
    .noTOFU()
    .build();

  c=(HttpURLConnection)new URL(getUrl()).openConnection();
  new TrustManagerBuilder().add(memo).applyTo(c);

  try {
    c.getInputStream();

    throw new AssertionFailedError("Expected SSLHandshakeException, did not get!");
  }
  catch (SSLHandshakeException e) {
    if (!(e.getCause() instanceof CertificateNotMemorizedException)) {
      throw e;
    }
  }
}
 
開發者ID:commonsguy,項目名稱:cwac-netsecurity,代碼行數:55,代碼來源:HURLMemorizationTests.java

示例10: testTOFU

import javax.net.ssl.SSLHandshakeException; //導入方法依賴的package包/類
@Test
public void testTOFU() throws Exception {
  MemorizingTrustManager memo=new MemorizingTrustManager.Builder()
    .saveTo(memoDir, "sekrit".toCharArray())
    .build();

  final TrustManagerBuilder tmb=new TrustManagerBuilder().add(memo);

  OkHttp3Integrator.applyTo(tmb, builder);
  OkHttpClient client=builder.build();
  Response response=client.newCall(buildRequest()).execute();
  Assert.assertEquals(getExpectedResponse(), response.body().string());

  response=client.newCall(buildRequest()).execute();
  Assert.assertEquals(getExpectedResponse(), response.body().string());

  MemorizingTrustManager memoNoTofu=new MemorizingTrustManager.Builder()
    .saveTo(memoDir, "sekrit".toCharArray())
    .noTOFU()
    .build();
  TrustManagerBuilder tmbNoTofu=new TrustManagerBuilder().add(memoNoTofu);
  OkHttpClient.Builder builderNoTofu=new OkHttpClient.Builder();

  OkHttp3Integrator.applyTo(tmbNoTofu, builderNoTofu);

  OkHttpClient clientNoTofu=builderNoTofu.build();

  response=clientNoTofu.newCall(buildRequest()).execute();
  Assert.assertEquals(getExpectedResponse(), response.body().string());

  memoNoTofu.clearAll(true);
  builderNoTofu=new OkHttpClient.Builder();
  OkHttp3Integrator.applyTo(tmbNoTofu, builderNoTofu);
  clientNoTofu=builderNoTofu.build();

  try {
    clientNoTofu.newCall(buildRequest()).execute();

    throw new AssertionFailedError("Expected SSLHandshakeException, did not get!");
  }
  catch (SSLHandshakeException e) {
    if (!(e.getCause() instanceof CertificateNotMemorizedException)) {
      throw e;
    }
  }
}
 
開發者ID:commonsguy,項目名稱:cwac-netsecurity,代碼行數:47,代碼來源:OkHttp3MemorizationTests.java

示例11: testDebugOverridesInvalidPin

import javax.net.ssl.SSLHandshakeException; //導入方法依賴的package包/類
@Test
public void testDebugOverridesInvalidPin() throws IOException, CertificateException {
    if (Build.VERSION.SDK_INT >= 24) {
        // This test will not work when using the Android N XML network policy because we can't
        // dynamically switch overridePins to false (as it is true in the XML policy)
        return;
    }
    if (Build.VERSION.SDK_INT < 17) {
        // TrustKit does not do anything for API level < 17 hence the connection will succeed
        return;
    }

    String serverHostname = "www.cacert.org";
    final DomainPinningPolicy domainPolicy = new DomainPinningPolicy.Builder()
            .setHostname(serverHostname)
            .setShouldEnforcePinning(true)
            .setPublicKeyHashes(new HashSet<String>() {{
                // Wrong pins
                add("AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA=");
                add("BBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBB=");
            }}).build();

    // Create a configuration with debug overrides enabled to add the cacert.org CA and to set
    // overridePins to false, making the connection fail
    TestableTrustKit.init(new HashSet<DomainPinningPolicy>() {{ add(domainPolicy); }},
            false,
            new HashSet<Certificate>(){{ add(caCertDotOrgRoot); }},
            InstrumentationRegistry.getContext(),
            mockReporter);

    // Create a TrustKit SocketFactory and ensure the connection fails
    // This means that debug-overrides properly enables the supplied debug CA cert but does not
    // disable pinning when overridePins is false
    SSLSocketFactory test = TestableTrustKit.getInstance().getSSLSocketFactory(serverHostname);
    boolean didReceivePinningError = false;
    try {
        test.createSocket(serverHostname, 443).getInputStream();
    } catch (SSLHandshakeException e) {
        if ((e.getCause() instanceof CertificateException
                && (e.getCause().getMessage().startsWith("Pin verification failed")))) {
            didReceivePinningError = true;
        }
    }
    assertTrue(didReceivePinningError);

    // Ensure the background reporter was called
    verify(mockReporter).pinValidationFailed(
            eq(serverHostname),
            eq(0),
            (List<X509Certificate>) org.mockito.Matchers.isNotNull(),
            (List<X509Certificate>) org.mockito.Matchers.isNotNull(),
            eq(TestableTrustKit.getInstance().getConfiguration().getPolicyForHostname(serverHostname)),
            eq(PinningValidationResult.FAILED)
    );
}
 
開發者ID:datatheorem,項目名稱:TrustKit-Android,代碼行數:56,代碼來源:SSLSocketFactoryTest.java


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