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


Java SSLParameters.setApplicationProtocols方法代碼示例

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


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

示例1: initSecure

import javax.net.ssl.SSLParameters; //導入方法依賴的package包/類
final ServerSocket initSecure(int port) throws Exception {
    ServerSocketFactory fac;
    if (sslContext != null) {
        fac = sslContext.getServerSocketFactory();
    } else {
        fac = SSLServerSocketFactory.getDefault();
    }
    SSLServerSocket se = (SSLServerSocket) fac.createServerSocket(port);
    SSLParameters sslp = se.getSSLParameters();
    sslp.setApplicationProtocols(new String[]{"h2"});
    se.setSSLParameters(sslp);
    se.setEnabledCipherSuites(se.getSupportedCipherSuites());
    se.setEnabledProtocols(se.getSupportedProtocols());
    // other initialisation here
    return se;
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:17,代碼來源:Http2TestServer.java

示例2: getSSLParameters

import javax.net.ssl.SSLParameters; //導入方法依賴的package包/類
/**
 * Returns the SSLParameters in effect for newly accepted connections.
 */
@Override
public synchronized SSLParameters getSSLParameters() {
    SSLParameters params = super.getSSLParameters();

    // the super implementation does not handle the following parameters
    params.setEndpointIdentificationAlgorithm(identificationProtocol);
    params.setAlgorithmConstraints(algorithmConstraints);
    params.setSNIMatchers(sniMatchers);
    params.setUseCipherSuitesOrder(preferLocalCipherSuites);
    params.setApplicationProtocols(applicationProtocols);

    return params;
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:17,代碼來源:SSLServerSocketImpl.java

示例3: test

import javax.net.ssl.SSLParameters; //導入方法依賴的package包/類
public static void test(boolean async) throws Exception {
    System.setProperty("javax.net.ssl.keyStore", KEYSTORE);
    System.setProperty("javax.net.ssl.keyStorePassword", PASSWORD);
    System.setProperty("javax.net.ssl.trustStore", KEYSTORE);
    System.setProperty("javax.net.ssl.trustStorePassword", PASSWORD);

    SSLServerSocketFactory factory =
            (SSLServerSocketFactory) SSLServerSocketFactory.getDefault();

    try (SSLServerSocket ssocket =
            (SSLServerSocket) factory.createServerSocket(RANDOM_PORT)) {

        // start server
        Thread server = new Thread(() -> {
            while (true) {
                System.out.println("server: ready");
                SSLParameters params = ssocket.getSSLParameters();
                params.setApplicationProtocols(new String[]{"h2"});
                ssocket.setSSLParameters(params);
                ready = true;
                try (SSLSocket socket = (SSLSocket) ssocket.accept()) {

                    // just read forever
                    System.out.println("server: accepted");
                    while (true) {
                        socket.getInputStream().read();
                    }
                } catch (IOException e) {
                    // ignore exceptions on server side
                    System.out.println("server: exception: " + e);
                }
            }
        });
        server.setDaemon(true);
        server.start();

        // wait for server is ready
        do {
            Thread.sleep(1000);
        } while (!ready);

        String uri = "https://localhost:" + ssocket.getLocalPort();
        if (async) {
            System.out.println(uri + ": Trying to connect asynchronously");
            connectAsync(uri);
        } else {
            System.out.println(uri + ": Trying to connect synchronously");
            connect(uri);
        }
    }
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:52,代碼來源:Timeout.java

示例4: test

import javax.net.ssl.SSLParameters; //導入方法依賴的package包/類
@Test
public void test() throws Exception {
    SSLContext sslContext = (new SimpleSSLContext()).get();
    ExecutorService exec = Executors.newCachedThreadPool();
    HttpClient client = HttpClient.newBuilder()
                                  .executor(exec)
                                  .sslContext(sslContext)
                                  .sslParameters(new SSLParameters(CIPHER_SUITES))
                                  .version(HTTP_2)
                                  .build();

    Http2TestServer httpsServer = null;
    try {
        SSLContext serverContext = (new SimpleSSLContext()).get();
        SSLParameters p = serverContext.getSupportedSSLParameters();
        p.setApplicationProtocols(new String[]{"h2"});
        httpsServer = new Http2TestServer(true,
                                          0,
                                          exec,
                                          serverContext);
        httpsServer.addHandler(new Http2EchoHandler(), "/");
        int httpsPort = httpsServer.getAddress().getPort();
        String httpsURIString = "https://127.0.0.1:" + httpsPort + "/bar/";

        httpsServer.start();
        URI uri = URI.create(httpsURIString);
        System.err.println("Request to " + uri);

        HttpRequest req = HttpRequest.newBuilder(uri)
                                .POST(fromString(SIMPLE_STRING))
                                .build();
        HttpResponse response;
        try {
            response = client.send(req, discard(null));
            throw new RuntimeException("Unexpected response: " + response);
        } catch (IOException e) {
            System.err.println("Caught Expected IOException: " + e);
        }
        System.err.println("DONE");
    } finally {
        if (httpsServer != null )  { httpsServer.stop(); }
        exec.shutdownNow();
    }
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:45,代碼來源:ErrorTest.java


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