本文整理匯總了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();
}
}
示例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();
}
示例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();
}
示例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);
}
}
示例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();
}
}
示例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();
}
}
示例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.");
}
}
示例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();
}
示例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! */ }
}
}
示例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();
}
}
示例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();
}
}
示例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());
}
}
示例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());
}
}
示例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);
}
示例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;
}
}