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


Java SSLServerSocket.accept方法代碼示例

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


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

示例1: doServerSide

import javax.net.ssl.SSLServerSocket; //導入方法依賴的package包/類
void doServerSide() throws Exception {
        SSLServerSocketFactory sslssf =
            (SSLServerSocketFactory) SSLServerSocketFactory.getDefault();
        SSLServerSocket sslServerSocket =
            (SSLServerSocket) sslssf.createServerSocket(serverPort);
        serverPort = sslServerSocket.getLocalPort();

        /*
         * Signal Client, we're ready for his connect.
         */
        serverReady = true;

        while (serverReady) {
            SSLSocket sslSocket = (SSLSocket) sslServerSocket.accept();
//            System.out.printf("  accept: %s%n", sslSocket);
            InputStream sslIS = sslSocket.getInputStream();
            OutputStream sslOS = sslSocket.getOutputStream();

            sslIS.read();
            sslOS.write(85);
            sslOS.flush();

            sslSocket.close();
        }
    }
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:26,代碼來源:SSLSessionFinalizeTest.java

示例2: doServerSide

import javax.net.ssl.SSLServerSocket; //導入方法依賴的package包/類
void doServerSide() throws Exception {
    SSLServerSocketFactory sslssf = getSSLServerSF();
    SSLServerSocket sslServerSocket =
        (SSLServerSocket) sslssf.createServerSocket(serverPort);

    // require client authentication.
    sslServerSocket.setNeedClientAuth(true);

    serverPort = sslServerSocket.getLocalPort();

    /*
     * Signal Client, we're ready for his connect.
     */
    serverReady = true;

    SSLSocket sslSocket = (SSLSocket) sslServerSocket.accept();
    InputStream sslIS = sslSocket.getInputStream();
    OutputStream sslOS = sslSocket.getOutputStream();

    sslIS.read();
    sslOS.write('A');
    sslOS.flush();

    sslSocket.close();
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:26,代碼來源:EmptyCertificateAuthorities.java

示例3: doServerSide

import javax.net.ssl.SSLServerSocket; //導入方法依賴的package包/類
void doServerSide() throws Exception {
    SSLServerSocketFactory sslssf =
        (SSLServerSocketFactory) SSLServerSocketFactory.getDefault();
    SSLServerSocket sslServerSocket =
        (SSLServerSocket) sslssf.createServerSocket(serverPort);

    serverPort = sslServerSocket.getLocalPort();

    /*
     * Signal Client, we're ready for his connect.
     */
    serverReady = true;

    SSLSocket sslSocket = (SSLSocket) sslServerSocket.accept();
    InputStream sslIS = sslSocket.getInputStream();
    OutputStream sslOS = sslSocket.getOutputStream();

    sslIS.read();
    sslOS.write('A');
    sslOS.flush();

    sslSocket.close();
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:24,代碼來源:GenericBlockCipher.java

示例4: process

import javax.net.ssl.SSLServerSocket; //導入方法依賴的package包/類
/**
 * Accept and process an incoming request. Only the TLS handshake is used here.
 * Incoming data is just consumed, and the socket is closed after that.
 *
 * @param sslServerSocket
 *            {@link SSLServerSocket} to accept connections from
 */
private void process(SSLServerSocket sslServerSocket) {
    try (SSLSocket sslSocket = (SSLSocket) sslServerSocket.accept()) {
        sslSocket.setEnabledCipherSuites(sslSocket.getSupportedCipherSuites());
        sslSocket.startHandshake();

        SSLSession sslSession = sslSocket.getSession();
        X509Certificate cert = (X509Certificate) sslSession.getLocalCertificates()[0];
        LOG.info("tls-sni: {}", domainsToString(cert));

        try (InputStream in = sslSocket.getInputStream()) {
            while (in.read() >= 0); //NOSONAR: intentional empty statement
        }
    } catch (Exception ex) {
        LOG.error("Failed to process request", ex);
    }
}
 
開發者ID:shred,項目名稱:acme4j,代碼行數:24,代碼來源:TlsSniServer.java

示例5: main

import javax.net.ssl.SSLServerSocket; //導入方法依賴的package包/類
public static void main(String[] args) throws Exception {
    int port = 7443;
    if (args.length >= 1) {
        port = Integer.parseInt(args[0]);
    }

    SSLServer ssl = new SSLServer();
    ssl.setTrustMaterial(TrustMaterial.TRUST_ALL);
    ssl.setCheckExpiry(false);
    ssl.setCheckCRL(false);
    ssl.setCheckHostname(false);
    ssl.setWantClientAuth(true);

    SSLServerSocket ss = (SSLServerSocket) ssl.createServerSocket(port, 3);
    System.out.println("SSL Echo server listening on port: " + port);
    while (true) {
        SSLSocket s = (SSLSocket) ss.accept();
        s.setSoTimeout(30000);
        EchoRunnable r = new EchoRunnable(s);
        new Thread(r).start();
    }

}
 
開發者ID:drankye,項目名稱:haox,代碼行數:24,代碼來源:SSLEchoServer.java

示例6: doServerSide

import javax.net.ssl.SSLServerSocket; //導入方法依賴的package包/類
void doServerSide() throws Exception {
    SSLContext context = generateSSLContext(false);
    SSLServerSocketFactory sslssf = context.getServerSocketFactory();
    SSLServerSocket sslServerSocket =
        (SSLServerSocket)sslssf.createServerSocket(serverPort);
    serverPort = sslServerSocket.getLocalPort();

    /*
     * Signal Client, we're ready for his connect.
     */
    serverReady = true;

    SSLSocket sslSocket = (SSLSocket)sslServerSocket.accept();
    try {
        sslSocket.setSoTimeout(5000);
        sslSocket.setSoLinger(true, 5);

        InputStream sslIS = sslSocket.getInputStream();
        OutputStream sslOS = sslSocket.getOutputStream();

        sslIS.read();
        sslOS.write('A');
        sslOS.flush();

        throw new Exception("EC curve secp224k1 should be disabled");
    } catch (SSLHandshakeException she) {
        // expected exception: no cipher suites in common
        System.out.println("Expected exception: " + she);
    } finally {
        sslSocket.close();
        sslServerSocket.close();
    }
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:34,代碼來源:ECCurvesconstraints.java

示例7: doServerSide

import javax.net.ssl.SSLServerSocket; //導入方法依賴的package包/類
void doServerSide() throws Exception {
    SSLServerSocketFactory sslssf =
        (SSLServerSocketFactory) SSLServerSocketFactory.getDefault();
    SSLServerSocket sslServerSocket =
        (SSLServerSocket) sslssf.createServerSocket(serverPort);

    serverPort = sslServerSocket.getLocalPort();

    /*
     * Signal Client, we're ready for his connect.
     */
    serverReady = true;

    SSLSocket sslSocket = (SSLSocket) sslServerSocket.accept();
    InputStream sslIS = sslSocket.getInputStream();
    OutputStream sslOS = sslSocket.getOutputStream();

    boolean interrupted = false;
    try {
        sslIS.read();
        sslOS.write('A');
        sslOS.flush();
    } catch (IOException ioe) {
        // get the expected exception
        interrupted = true;
    } finally {
        sslSocket.close();
    }

    if (!interrupted) {
        throw new SSLHandshakeException(
            "A weak cipher suite is negotiated, " +
            "TLSv1.1 must not negotiate the exportable cipher suites.");
    }
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:36,代碼來源:ExportableStreamCipher.java

示例8: doServerSide

import javax.net.ssl.SSLServerSocket; //導入方法依賴的package包/類
void doServerSide() throws Exception {
    SSLServerSocketFactory sslssf =
        (SSLServerSocketFactory) SSLServerSocketFactory.getDefault();
    SSLServerSocket sslServerSocket =
        (SSLServerSocket) sslssf.createServerSocket(serverPort);

    // enable a stream cipher
    sslServerSocket.setEnabledCipherSuites(
        new String[] {"SSL_RSA_WITH_RC4_128_MD5"});

    serverPort = sslServerSocket.getLocalPort();

    /*
     * Signal Client, we're ready for his connect.
     */
    serverReady = true;

    SSLSocket sslSocket = (SSLSocket) sslServerSocket.accept();
    InputStream sslIS = sslSocket.getInputStream();
    OutputStream sslOS = sslSocket.getOutputStream();

    sslIS.read();
    sslOS.write('A');
    sslOS.flush();

    sslSocket.close();
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:28,代碼來源:GenericStreamCipher.java

示例9: doServerSide

import javax.net.ssl.SSLServerSocket; //導入方法依賴的package包/類
void doServerSide() throws Exception {
    SSLServerSocketFactory sslssf =
        (SSLServerSocketFactory) SSLServerSocketFactory.getDefault();
    SSLServerSocket sslServerSocket =
        (SSLServerSocket) sslssf.createServerSocket(serverPort);
    serverPort = sslServerSocket.getLocalPort();

    /*
     * Signal Client, we're ready for his connect.
     */
    serverReady = true;
    SSLSocket sslSocket = null;
    try {
        sslSocket = (SSLSocket) sslServerSocket.accept();
        sslSocket.setSoTimeout(TIMEOUT);
        readOneRequest(sslSocket.getInputStream());
        sslSocket.getOutputStream().write(replyString.getBytes());

        readOneRequest(sslSocket.getInputStream());
        sslSocket.getOutputStream().write(replyString.getBytes());
    } catch (Exception e) {
        e.printStackTrace();
    } finally {
        try {
            if (sslSocket != null) { sslSocket.close(); }
            sslServerSocket.close();
        } catch (IOException unused)  {  /* gulp!burp! */   }
    }
}
 
開發者ID:campolake,項目名稱:openjdk9,代碼行數:30,代碼來源:CookieHttpsClientTest.java

示例10: run

import javax.net.ssl.SSLServerSocket; //導入方法依賴的package包/類
@Override
public void run() {

  // Specifying the Keystore details
  // System.setProperty("javax.net.ssl.keyStore", config.getSslKeyStoreName());
  // System.setProperty("javax.net.ssl.keyStorePassword", config.getSslCertPassword());

  try {
    // Initialize the Server Socket
    SSLContext sslContext = SSLContext.getInstance("SSL");
    sslContext.init(config.getKmf().getKeyManagers(), null, null);

    SSLServerSocketFactory factory = sslContext.getServerSocketFactory();
    log.info("factory created");

    SSLServerSocket serverSocket = (SSLServerSocket) factory.createServerSocket(config.getAsPortSsl());
    log.info("server socket created");

    // SSLContext sslContext = config.getSslContext();
    // SSLServerSocketFactory factory = (SSLServerSocketFactory)
    // sslContext.getServerSocketFactory();
    //
    // SSLServerSocket sslServerSocket =
    // (SSLServerSocket) factory.createServerSocket(config.getAsPortSsl());

    log.info("AS SSL thread started on port " + config.getAsPortSsl());
    while (true) {
      Socket clientSocket = serverSocket.accept();
      log.info("New client connected using SSL");
      threadPool.execute(new AppHandler(clientSocket, config));
    }
  } catch (IOException | NoSuchAlgorithmException | KeyManagementException e) {
    log.error("Could not create SSL context: " + e);
    e.printStackTrace();
  }
}
 
開發者ID:RapidProjectH2020,項目名稱:rapid-linux,代碼行數:37,代碼來源:ClientListenerSSL.java

示例11: run

import javax.net.ssl.SSLServerSocket; //導入方法依賴的package包/類
@Override
public void run() {

  Log.i(TAG, "ClientListenerSSL started");

  try {
    SSLContext sslContext = SSLContext.getInstance("SSL");
    sslContext.init(config.getKmf().getKeyManagers(), null, null);

    SSLServerSocketFactory factory =
        (SSLServerSocketFactory) sslContext.getServerSocketFactory();
    Log.i(TAG, "factory created");

    SSLServerSocket serverSocket =
        (SSLServerSocket) factory.createServerSocket(config.getSslClonePort());
    Log.i(TAG, "server socket created");

    // If we want also the client to authenticate himself
    // serverSocket.setNeedClientAuth(true); // default is false

    while (true) {
      // Log.i(TAG, "Saved session IDs: ");
      // Enumeration<byte[]> sessionIDs = sslContext.getServerSessionContext().getIds();
      // while(sessionIDs.hasMoreElements()) {
      // Log.i(TAG, "ID: " + RapidUtils.bytesToHex(sessionIDs.nextElement()));
      // }
      // Log.i(TAG, "");
      //
      Socket clientSocket = serverSocket.accept();
      Log.i(TAG, "New client connected using SSL");
      new AppHandler(clientSocket, context, config);
    }

  } catch (IOException | NoSuchAlgorithmException | KeyManagementException e1) {
    e1.printStackTrace();
  }
}
 
開發者ID:RapidProjectH2020,項目名稱:offloading-framework-android,代碼行數:38,代碼來源:AccelerationServer.java

示例12: iniciarServicio

import javax.net.ssl.SSLServerSocket; //導入方法依賴的package包/類
private static void iniciarServicio(final int puerto, final char[] password) {
    try {

        SSLContext context = SSLContext.getInstance("SSL");
        KeyManagerFactory kmf = KeyManagerFactory.getInstance("SunX509");

        KeyStore ks = KeyStore.getInstance("JKS");

        ks.load(new FileInputStream("src/cert/keystore.jks"), password);
        kmf.init(ks, "PrometheuS".toCharArray());

        context.init(kmf.getKeyManagers(), null, null);
        SSLServerSocketFactory factory = context.getServerSocketFactory();
        SSLServerSocket socket = (SSLServerSocket) factory.createServerSocket(puerto);


        while (true) {

            Socket userSocket = socket.accept();

            Servicio serv = new Servicio(userSocket);
            serv.start();
        }

    } catch (NoSuchAlgorithmException | KeyStoreException |
            CertificateException | UnrecoverableKeyException |
            KeyManagementException | IOException ex) {
        System.out.println("ERROR: " + ex.getMessage());
    }
}
 
開發者ID:Prometheus-ETSIIT,項目名稱:locaviewer,代碼行數:31,代碼來源:Servidor.java

示例13: iniciarServicio

import javax.net.ssl.SSLServerSocket; //導入方法依賴的package包/類
private static void iniciarServicio(final int puerto, final char[] password) {
    try {
     
        SSLContext context = SSLContext.getInstance("SSL");
        KeyManagerFactory kmf = KeyManagerFactory.getInstance("SunX509");

        KeyStore ks = KeyStore.getInstance("JKS");

        ks.load(new FileInputStream("src/cert/keystore.jks"), password);
        kmf.init(ks, "PrometheuS".toCharArray());

        context.init(kmf.getKeyManagers(), null, null);
        SSLServerSocketFactory factory = context.getServerSocketFactory();
        SSLServerSocket socket = (SSLServerSocket) factory.createServerSocket(puerto);


        while (true) {

            Socket userSocket = socket.accept();

            Servicio serv = new Servicio(userSocket);
            serv.start();
        }

    } catch (NoSuchAlgorithmException | KeyStoreException |
            CertificateException | UnrecoverableKeyException | 
            KeyManagementException | IOException ex) {
        System.out.println("ERROR: " + ex.getMessage());
    }
}
 
開發者ID:Prometheus-ETSIIT,項目名稱:locaviewer,代碼行數:31,代碼來源:Servidor.java

示例14: testMutualSSL

import javax.net.ssl.SSLServerSocket; //導入方法依賴的package包/類
@Test
public void testMutualSSL() throws Exception {

	Security.addProvider(new BeIDProvider());

	final KeyPair serverKeyPair = generateKeyPair();
	final PrivateKey serverPrivateKey = serverKeyPair.getPrivate();
	final DateTime notBefore = new DateTime();
	final DateTime notAfter = notBefore.plusDays(1);
	final X509Certificate serverCertificate = generateCACertificate(serverKeyPair, "CN=Test", notBefore, notAfter);

	final KeyManager keyManager = new ServerTestX509KeyManager(serverPrivateKey, serverCertificate);
	final TrustManager trustManager = new ServerTestX509TrustManager();
	final SSLContext sslContext = SSLContext.getInstance("TLS");
	sslContext.init(new KeyManager[] { keyManager }, new TrustManager[] { trustManager }, new SecureRandom());

	final SSLServerSocketFactory sslServerSocketFactory = sslContext.getServerSocketFactory();

	final int serverPort = 8443;
	final SSLServerSocket sslServerSocket = (SSLServerSocket) sslServerSocketFactory.createServerSocket(serverPort);

	sslServerSocket.setNeedClientAuth(true);

	final TestRunnable testRunnable = new TestRunnable(serverPort);
	final Thread thread = new Thread(testRunnable);
	thread.start();

	SSLSocket sslSocket = (SSLSocket) sslServerSocket.accept();
	LOGGER.debug("server accepted");
	InputStream inputStream = sslSocket.getInputStream();
	int result = inputStream.read();
	LOGGER.debug("result: {}", result);
	assertEquals(12, result);
	SSLSession sslSession = sslSocket.getSession();
	sslSession.invalidate();
	sslSocket = (SSLSocket) sslServerSocket.accept();
	inputStream = sslSocket.getInputStream();
	result = inputStream.read();
	LOGGER.debug("result: {}", result);
	assertEquals(34, result);
}
 
開發者ID:e-Contract,項目名稱:commons-eid,代碼行數:42,代碼來源:SSLTest.java

示例15: run

import javax.net.ssl.SSLServerSocket; //導入方法依賴的package包/類
public void run() {
    try {
        store = provideKeys ? getKeyStore(keys) : null;
        KeyManager[] keyManagers = store != null ? getKeyManagers(store) : null;
        TrustManager[] trustManagers = new TrustManager[] { trustManager };

        SSLContext sslContext = SSLContext.getInstance("TLS");
        sslContext.init(keyManagers, trustManagers, null);

        SSLServerSocket serverSocket = (SSLServerSocket)sslContext
                .getServerSocketFactory().createServerSocket();

        if (clientAuth == CLIENT_AUTH_WANTED) {
            serverSocket.setWantClientAuth(true);
        } else if (clientAuth == CLIENT_AUTH_NEEDED) {
            serverSocket.setNeedClientAuth(true);
        } else {
            serverSocket.setWantClientAuth(false);
        }

        serverSocket.bind(new InetSocketAddress(port));

        SSLSocket clientSocket = (SSLSocket)serverSocket.accept();

        InputStream istream = clientSocket.getInputStream();
        byte[] buffer = new byte[1024];
        istream.read(buffer);

        OutputStream ostream = clientSocket.getOutputStream();
        ostream.write(testData.getBytes());
        ostream.flush();

        while (notFinished) {
            Thread.currentThread().sleep(500);
        }

        clientSocket.close();
        serverSocket.close();

    } catch (Exception ex) {
        exception = ex;
    }
}
 
開發者ID:keplersj,項目名稱:In-the-Box-Fork,代碼行數:44,代碼來源:SSLSessionTest.java


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