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


Java SSLServerSocket.setNeedClientAuth方法代碼示例

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


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

示例1: finishServerSocket

import javax.net.ssl.SSLServerSocket; //導入方法依賴的package包/類
/**
 * Configure the SSLServerSocket based on this SocketCreator's settings.
 */
private void finishServerSocket(SSLServerSocket serverSocket) throws IOException {
  serverSocket.setUseClientMode(false);
  if (this.sslConfig.isRequireAuth()) {
    // serverSocket.setWantClientAuth( true );
    serverSocket.setNeedClientAuth(true);
  }
  serverSocket.setEnableSessionCreation(true);

  // restrict protocols
  String[] protocols = this.sslConfig.getProtocolsAsStringArray();
  if (!"any".equalsIgnoreCase(protocols[0])) {
    serverSocket.setEnabledProtocols(protocols);
  }
  // restrict ciphers
  String[] ciphers = this.sslConfig.getCiphersAsStringArray();
  if (!"any".equalsIgnoreCase(ciphers[0])) {
    serverSocket.setEnabledCipherSuites(ciphers);
  }
}
 
開發者ID:ampool,項目名稱:monarch,代碼行數:23,代碼來源:SocketCreator.java

示例2: configureServerSocket

import javax.net.ssl.SSLServerSocket; //導入方法依賴的package包/類
/**
 * Set the server socket configuration to our required
 * QOS values.
 *
 * A small experiment shows that setting either (want, need) parameter to either true or false sets the
 * other parameter to false.
 *
 * @param serverSocket
 *               The newly created SSLServerSocket.
 *
 * @throws IOException if server socket can't be configured
 */
private void configureServerSocket(SSLServerSocket serverSocket) throws IOException {
    // set the authentication value and cipher suite info.
    serverSocket.setEnabledCipherSuites(cipherSuites);
    if (clientAuthRequired) {
        serverSocket.setNeedClientAuth(true);
    } else if (clientAuthSupported) {
        serverSocket.setWantClientAuth(true);
    } else {
        serverSocket.setNeedClientAuth(false); //could set want with the same effect
    }
    serverSocket.setSoTimeout(SOCKET_TIMEOUT_MS);

    if (log.isDebugEnabled()) {
        log.debug("Created SSL server socket on port " + serverSocket.getLocalPort());
        log.debug("    client authentication " + (clientAuthSupported ? "SUPPORTED" : "UNSUPPORTED"));
        log.debug("    client authentication " + (clientAuthRequired ? "REQUIRED" : "OPTIONAL"));
        log.debug("    cipher suites:");

        for (int i = 0; i < cipherSuites.length; i++) {
            log.debug("    " + cipherSuites[i]);
        }
    }
}
 
開發者ID:RuiChen08,項目名稱:dacapobench,代碼行數:36,代碼來源:SocketFactory.java

示例3: 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

示例4: newSslServerSocket

import javax.net.ssl.SSLServerSocket; //導入方法依賴的package包/類
public SSLServerSocket newSslServerSocket(String host,int port,int backlog) throws IOException {
    SSLServerSocketFactory factory = sslContext.getServerSocketFactory();

    SSLServerSocket socket = 
        (SSLServerSocket) (host==null ?
      factory.createServerSocket(port, backlog):
      factory.createServerSocket(port, backlog, InetAddress.getByName(host)));

    if (sslConfig.getWantClientAuth())
        socket.setWantClientAuth(sslConfig.getWantClientAuth());
    if (sslConfig.getNeedClientAuth())
        socket.setNeedClientAuth(sslConfig.getNeedClientAuth());

    socket.setEnabledCipherSuites(selectCipherSuites(socket.getEnabledCipherSuites(),
			 socket.getSupportedCipherSuites()));
    socket.setEnabledProtocols(selectProtocols(socket.getEnabledProtocols(),socket.getSupportedProtocols()));
	
    return socket;
}
 
開發者ID:nkasvosve,項目名稱:beyondj,代碼行數:20,代碼來源:SslContextFactory.java

示例5: start

import javax.net.ssl.SSLServerSocket; //導入方法依賴的package包/類
/**
 * Starts this test server.
 */
public void start() throws Exception {
    Asserts.check(servicedSocket == null, "Already running");
    final ServerSocket ssock;
    if (sslcontext != null) {
        final SSLServerSocketFactory sf = sslcontext.getServerSocketFactory();
        final SSLServerSocket sslsock = (SSLServerSocket) sf.createServerSocket();
        if (forceSSLAuth) {
            sslsock.setNeedClientAuth(true);
        } else {
            sslsock.setWantClientAuth(true);
        }
        ssock = sslsock;
    } else {
        ssock = new ServerSocket();
    }

    ssock.setReuseAddress(true); // probably pointless for port '0'
    ssock.bind(TEST_SERVER_ADDR);
    servicedSocket = ssock;

    listenerThread = new ListenerThread();
    listenerThread.setDaemon(false);
    listenerThread.start();
}
 
開發者ID:reportportal,項目名稱:client-java-httpclient-repacked,代碼行數:28,代碼來源:LocalTestServer.java

示例6: createServer

import javax.net.ssl.SSLServerSocket; //導入方法依賴的package包/類
private static GfxdTSSLServerSocket createServer(
    SSLServerSocketFactory factory, InetSocketAddress bindAddress,
    SocketParameters params) throws TTransportException {
  try {
    SSLServerSocket serverSocket = (SSLServerSocket)factory
        .createServerSocket(bindAddress.getPort(), 100,
            bindAddress.getAddress());
    if (params != null) {
      if (params.getSSLEnabledProtocols() != null) {
        serverSocket.setEnabledProtocols(params.getSSLEnabledProtocols());
      }
      if (params.getSSLCipherSuites() != null) {
        serverSocket.setEnabledCipherSuites(params.getSSLCipherSuites());
      }
      serverSocket.setNeedClientAuth(params.getSSLClientAuth());
    }
    return new GfxdTSSLServerSocket(serverSocket, bindAddress, params);
  } catch (Exception e) {
    throw new TTransportException(TTransportException.NOT_OPEN,
        "Could not bind to host:port " + bindAddress.toString(), e);
  }
}
 
開發者ID:gemxd,項目名稱:gemfirexd-oss,代碼行數:23,代碼來源:GfxdTSSLServerSocketFactory.java

示例7: initSslServerSocket

import javax.net.ssl.SSLServerSocket; //導入方法依賴的package包/類
/**
 * Initializes the SSL server socket. Configures the certificate request
 * (need or want) and the enabled cipher suites.
 * 
 * @param sslServerSocket
 *            The server socket to initialize.
 * @return The initialized server socket.
 */
protected SSLServerSocket initSslServerSocket(
        SSLServerSocket sslServerSocket) {
    if (getContextFactory().isNeedClientAuthentication()) {
        sslServerSocket.setNeedClientAuth(true);
    } else if (getContextFactory().isWantClientAuthentication()) {
        sslServerSocket.setWantClientAuth(true);
    }

    if ((getContextFactory().getEnabledCipherSuites() != null)
            || (getContextFactory().getDisabledCipherSuites() != null)) {
        sslServerSocket.setEnabledCipherSuites(getContextFactory()
                .getSelectedCipherSuites(
                        sslServerSocket.getSupportedCipherSuites()));
    }

    if ((getContextFactory().getEnabledProtocols() != null)
            || (getContextFactory().getDisabledProtocols() != null)) {
        sslServerSocket.setEnabledProtocols(getContextFactory()
                .getSelectedSslProtocols(
                        sslServerSocket.getSupportedProtocols()));
    }

    return sslServerSocket;
}
 
開發者ID:restlet,項目名稱:restlet-framework,代碼行數:33,代碼來源:WrapperSslServerSocketFactory.java

示例8: newSslServerSocket

import javax.net.ssl.SSLServerSocket; //導入方法依賴的package包/類
public SSLServerSocket newSslServerSocket(String host,int port,int backlog) throws IOException
{
    SSLServerSocketFactory factory = _context.getServerSocketFactory();

    SSLServerSocket socket =
        (SSLServerSocket) (host==null ?
                    factory.createServerSocket(port,backlog):
                    factory.createServerSocket(port,backlog,InetAddress.getByName(host)));

    if (getWantClientAuth())
        socket.setWantClientAuth(getWantClientAuth());
    if (getNeedClientAuth())
        socket.setNeedClientAuth(getNeedClientAuth());

    socket.setEnabledCipherSuites(selectCipherSuites(
                                        socket.getEnabledCipherSuites(),
                                        socket.getSupportedCipherSuites()));
    socket.setEnabledProtocols(selectProtocols(socket.getEnabledProtocols(),socket.getSupportedProtocols()));

    return socket;
}
 
開發者ID:itead,項目名稱:IoTgo_Android_App,代碼行數:22,代碼來源:SslContextFactory.java

示例9: test_NeedClientAuth

import javax.net.ssl.SSLServerSocket; //導入方法依賴的package包/類
/**
 * @throws IOException
 * @tests javax.net.ssl.SSLServerSocket#setNeedClientAuth(boolean need)
 * @tests javax.net.ssl.SSLServerSocket#getNeedClientAuthCreation()
 */
@TestTargets({
    @TestTargetNew(
        level = TestLevel.COMPLETE,
        notes = "",
        method = "setNeedClientAuth",
        args = {boolean.class}
    ),
    @TestTargetNew(
        level = TestLevel.COMPLETE,
        notes = "",
        method = "getNeedClientAuth",
        args = {}
    )
})
public void test_NeedClientAuth() throws Exception {
    SSLServerSocket sss = getSSLServerSocket();
    sss.setNeedClientAuth(true);
    assertTrue(sss.getNeedClientAuth());
    sss.setNeedClientAuth(false);
    assertFalse(sss.getNeedClientAuth());
}
 
開發者ID:keplersj,項目名稱:In-the-Box-Fork,代碼行數:27,代碼來源:SSLServerSocketTest.java

示例10: TestAmqpPeerRunner

import javax.net.ssl.SSLServerSocket; //導入方法依賴的package包/類
public TestAmqpPeerRunner(TestAmqpPeer peer, SSLContext sslContext, boolean needClientCert) throws IOException
{
    int port = useFixedPort ? PORT : 0;
    this.needClientCert = needClientCert;

    if (sslContext == null)
    {
        _serverSocket = new ServerSocket(port);
    }
    else
    {
        SSLServerSocketFactory socketFactory = sslContext.getServerSocketFactory();
        _serverSocket = socketFactory.createServerSocket(port);

        SSLServerSocket sslServerSocket = (SSLServerSocket) _serverSocket;
        if (this.needClientCert)
        {
            sslServerSocket.setNeedClientAuth(true);
        }
    }

    _testFrameParser = new TestFrameParser(peer);
    _peer = peer;
}
 
開發者ID:apache,項目名稱:qpid-jms,代碼行數:25,代碼來源:TestAmqpPeerRunner.java

示例11: testSetGetWantClientAuth

import javax.net.ssl.SSLServerSocket; //導入方法依賴的package包/類
/**
 * setWantClientAuth(boolean want) method testing.
 * getWantClientAuth() method testing.
 */
public void testSetGetWantClientAuth() throws Exception {
    SSLServerSocket ssocket = createSSLServerSocket();

    ssocket.setNeedClientAuth(true);
    ssocket.setWantClientAuth(false);
    assertFalse("Result does not correspond to expected",
            ssocket.getWantClientAuth());
    assertFalse("Socket did not reset its want client auth state",
            ssocket.getNeedClientAuth());
    ssocket.setNeedClientAuth(true);
    ssocket.setWantClientAuth(true);
    assertTrue("Result does not correspond to expected",
            ssocket.getWantClientAuth());
    assertFalse("Socket did not reset its want client auth state",
            ssocket.getNeedClientAuth());
}
 
開發者ID:shannah,項目名稱:cn1,代碼行數:21,代碼來源:SSLServerSocketImplTest.java

示例12: createServerSocket

import javax.net.ssl.SSLServerSocket; //導入方法依賴的package包/類
private ServerSocket createServerSocket( int port , int tcpBackLog , InetAddress localAddr , boolean useSSL ) throws JMSException
{
    try
    {
        if (useSSL)
        {
            SSLServerSocket socket = (SSLServerSocket)createSSLContext().getServerSocketFactory().createServerSocket(port,tcpBackLog,localAddr);
            socket.setNeedClientAuth(false);
            return socket;
        }
        else
            return new ServerSocket(port,tcpBackLog,localAddr);
    }
    catch (Exception e)
    {
        throw new FFMQException("Cannot create server socket","NETWORK_ERROR",e);
    }
}
 
開發者ID:timewalker74,項目名稱:ffmq,代碼行數:19,代碼來源:TcpListener.java

示例13: createServerSocket

import javax.net.ssl.SSLServerSocket; //導入方法依賴的package包/類
@Override
public ServerSocket createServerSocket(int port) throws IOException  {
    SSLServerSocket sslServerSocket =
            (SSLServerSocket) sslServerSocketFactory.createServerSocket(port, 0, bindAddress);
    if (getEnabledCipherSuites() != null) {
        sslServerSocket.setEnabledCipherSuites(getEnabledCipherSuites());
    }
    if (getEnabledProtocols() == null) {
        sslServerSocket.setEnabledProtocols(defaultProtocols);
    } else {
        sslServerSocket.setEnabledProtocols(getEnabledProtocols());
    }
    sslServerSocket.setNeedClientAuth(getNeedClientAuth());
    return sslServerSocket;
}
 
開發者ID:liaokailin,項目名稱:tomcat7,代碼行數:16,代碼來源:JmxRemoteLifecycleListener.java

示例14: configureClientAuth

import javax.net.ssl.SSLServerSocket; //導入方法依賴的package包/類
/**
 * Configure Client authentication for this version of JSSE.  The
 * JSSE included in Java 1.4 supports the 'want' value.  Prior
 * versions of JSSE will treat 'want' as 'false'.
 * @param socket the SSLServerSocket
 */
protected void configureClientAuth(SSLServerSocket socket){
    if (wantClientAuth){
        socket.setWantClientAuth(wantClientAuth);
    } else {
        socket.setNeedClientAuth(requireClientAuth);
    }
}
 
開發者ID:liaokailin,項目名稱:tomcat7,代碼行數:14,代碼來源:JSSESocketFactory.java

示例15: init

import javax.net.ssl.SSLServerSocket; //導入方法依賴的package包/類
public void init() throws Exception {
	
	//這個類是原生包中的SSL連接的上下文類
	SSLContext context = SSLContext.getInstance("SSL");
	
	//服務器端證書庫
	KeyStore keystore = KeyStore.getInstance(KeyStore.getDefaultType());
	FileInputStream keystoreFis = new FileInputStream(keystorePath);
	keystore.load(keystoreFis, keystorePassword.toCharArray());
	//信任證書庫
	KeyStore trustKeystore = KeyStore.getInstance("jks");
	FileInputStream trustKeystoreFis = new FileInputStream(trustKeystorePath);
	trustKeystore.load(trustKeystoreFis, truststorePassword.toCharArray());
	
	//密鑰庫
	KeyManagerFactory kmf = KeyManagerFactory.getInstance("sunx509");
	kmf.init(keystore, keystorePassword.toCharArray());

	//信任庫
	TrustManagerFactory tmf = TrustManagerFactory.getInstance("sunx509");
	tmf.init(trustKeystore);
	
	//初始化SSL上下文
	context.init(kmf.getKeyManagers(), tmf.getTrustManagers(), null);
	//初始化SSLSocket
	sslServerSocket = (SSLServerSocket)context.getServerSocketFactory().createServerSocket(port);
	//設置這個SSLServerSocket需要授權的客戶端訪問
	sslServerSocket.setNeedClientAuth(true);
	
	keystoreFis.close();
	trustKeystoreFis.close();
	System.out.println("SSLServer initialized.");
}
 
開發者ID:strictnerd,項目名稱:LearningSummary,代碼行數:34,代碼來源:SSLServer.java


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