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


Java ServerSocketChannel類代碼示例

本文整理匯總了Java中java.nio.channels.ServerSocketChannel的典型用法代碼示例。如果您正苦於以下問題:Java ServerSocketChannel類的具體用法?Java ServerSocketChannel怎麽用?Java ServerSocketChannel使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


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

示例1: bind

import java.nio.channels.ServerSocketChannel; //導入依賴的package包/類
protected void
bind(
	ServerSocketChannel	ssc,
	InetAddress			address,
	int					port )

	throws IOException
{
	if ( address == null ){

		ssc.socket().bind( new InetSocketAddress( port ), 1024 );

	}else{

		ssc.socket().bind( new InetSocketAddress( address, port ), 1024 );
	}
}
 
開發者ID:BiglySoftware,項目名稱:BiglyBT,代碼行數:18,代碼來源:NetworkAdminImpl.java

示例2: OpenSockets

import java.nio.channels.ServerSocketChannel; //導入依賴的package包/類
private synchronized void OpenSockets() {
	if (mode == CLIENT) {
		try
		{
			attemptClientConnection();
			receiving = true;
		} catch (IOException e) {
			log.error(e);
		}
	} else if (mode == SERVER) {
		try {

			selector = Selector.open();
			serverSocketChannel = ServerSocketChannel.open();
			serverSocketChannel.configureBlocking(false);
			serverSocketChannel.socket().bind(new InetSocketAddress(port));
			serverSocketChannel.register(selector, SelectionKey.OP_ACCEPT);
			receiving = true;
		} catch (IOException ex) {
			selector = null;
		}

	}
}
 
開發者ID:Esri,項目名稱:defense-solutions-proofs-of-concept,代碼行數:25,代碼來源:TcpSquirtOutboundTransport.java

示例3: acceptConnection

import java.nio.channels.ServerSocketChannel; //導入依賴的package包/類
private final void acceptConnection(final SelectionKey key, MMOConnection<T> con)
{
    ServerSocketChannel ssc = (ServerSocketChannel) key.channel();
    SocketChannel sc;

    try
    {
        while ((sc = ssc.accept()) != null)
        {
            if (_acceptFilter == null || _acceptFilter.accept(sc))
            {
                sc.configureBlocking(false);
                SelectionKey clientKey = sc.register(_selector, SelectionKey.OP_READ);
                con = new MMOConnection<T>(this, sc.socket(), clientKey);
                con.setClient(_clientFactory.create(con));
                clientKey.attach(con);
            }
            else
                sc.socket().close();
        }
    }
    catch (IOException e)
    {
        e.printStackTrace();
    }
}
 
開發者ID:L2jBrasil,項目名稱:L2jBrasil,代碼行數:27,代碼來源:SelectorThread.java

示例4: bindNIOServerSocket

import java.nio.channels.ServerSocketChannel; //導入依賴的package包/類
/**
 * Creates a NIO ServerSocketChannel, and gets the ServerSocket from
 * there. Then binds the obtained socket.
 * This fails on Windows with Oracle JDK1.6.0u33, if the passed InetAddress is a
 * IPv6 address. Works on Oracle JDK 1.7.
 */
private void bindNIOServerSocket(InetAddress inetAddr) throws IOException {
  while (true) {
    int port = HBaseTestingUtility.randomFreePort();
    InetSocketAddress addr = new InetSocketAddress(inetAddr, port);
    ServerSocketChannel channel = null;
    ServerSocket serverSocket = null;
    try {
      channel = ServerSocketChannel.open();
      serverSocket = channel.socket();
      serverSocket.bind(addr); // This does not work
      break;
    } catch (BindException ex) {
      //continue
    } finally {
      if (serverSocket != null) {
        serverSocket.close();
      }
      if (channel != null) {
        channel.close();
      }
    }  
  }
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:30,代碼來源:TestIPv6NIOServerSocketChannel.java

示例5: accept

import java.nio.channels.ServerSocketChannel; //導入依賴的package包/類
/**
 * {@inheritDoc}
 */
@Override
protected NioSession accept(IoProcessor<NioSession> processor, ServerSocketChannel handle) throws Exception {

    SelectionKey key = handle.keyFor(selector);

    if ((key == null) || (!key.isValid()) || (!key.isAcceptable())) {
        return null;
    }

    // accept the connection from the client
    SocketChannel ch = handle.accept();

    if (ch == null) {
        return null;
    }

    return new NioSocketSession(this, processor, ch);
}
 
開發者ID:eclipse,項目名稱:neoscada,代碼行數:22,代碼來源:NioSocketAcceptor.java

示例6: configure

import java.nio.channels.ServerSocketChannel; //導入依賴的package包/類
@Override
public void configure(InetSocketAddress addr, int maxcc) throws IOException {
    configureSaslLogin();
    /**
     * thread是ServerCnxnFactory的主線程先啟動;然後再啟動NIO服務器
     * @see ServerCnxnFactory#run也已經被執行了
     * 此時客戶端可以訪問zk的2181端口;但是還無法處理客戶端的請求
     */
    thread = new ZooKeeperThread(this, "NIOServerCxn.Factory:" + addr);
    //線程後台運行
    thread.setDaemon(true);
    maxClientCnxns = maxcc;
    //??
    this.ss = ServerSocketChannel.open();
    //??
    ss.socket().setReuseAddress(true);
    LOG.info("binding to port " + addr);
    ss.socket().bind(addr);
    //非阻塞
    ss.configureBlocking(false);
    //??
    ss.register(selector, SelectionKey.OP_ACCEPT);
}
 
開發者ID:maoling,項目名稱:fuck_zookeeper,代碼行數:24,代碼來源:NIOServerCnxnFactory.java

示例7: TunnelServer

import java.nio.channels.ServerSocketChannel; //導入依賴的package包/類
public TunnelServer(int port, Selector selector) throws IOException {
    ServerSocketChannel serverSocketChannel = ServerSocketChannel.open();
    serverSocketChannel.configureBlocking(false);
    // ServerSocketChannel.bind() requires API 24
    serverSocketChannel.socket().bind(new InetSocketAddress(Inet4Address.getLoopbackAddress(), port));

    SelectionHandler socketChannelHandler = (selectionKey) -> {
        try {
            ServerSocketChannel channel = (ServerSocketChannel) selectionKey.channel();
            acceptClient(selector, channel);
        } catch (IOException e) {
            Log.e(TAG, "Cannot accept client", e);
        }
    };
    serverSocketChannel.register(selector, SelectionKey.OP_ACCEPT, socketChannelHandler);
}
 
開發者ID:Genymobile,項目名稱:gnirehtet,代碼行數:17,代碼來源:TunnelServer.java

示例8: selectFailure

import java.nio.channels.ServerSocketChannel; //導入依賴的package包/類
public void
 selectFailure(
VirtualAbstractSelectorListener		listener,
AbstractSelectableChannel 			sc,
Object 								attachment,
Throwable							msg)
 {
  if ( op == OP_ACCEPT ){

	  ((VirtualAcceptSelectorListener)listener).selectFailure( VirtualChannelSelector.this, (ServerSocketChannel)sc, attachment, msg );
  }else{

	  ((VirtualSelectorListener)listener).selectFailure( VirtualChannelSelector.this, (SocketChannel)sc, attachment, msg );

  }
 }
 
開發者ID:BiglySoftware,項目名稱:BiglyBT,代碼行數:17,代碼來源:VirtualChannelSelector.java

示例9: main

import java.nio.channels.ServerSocketChannel; //導入依賴的package包/類
public static void main(String args[]) throws Exception {
    InetAddress iaddr = InetAddress.getLocalHost();

    try ( ServerSocket ss = new ServerSocket(0);
          Socket s1 = new Socket(iaddr, ss.getLocalPort());
          Socket s2 = ss.accept() ) {

        test(s1, s2, "Testing NET");
    }

    // check the NIO socket adapter
    try (ServerSocketChannel sc = ServerSocketChannel.open().bind(null);
         SocketChannel s1 = SocketChannel.open(
                 new InetSocketAddress(iaddr, sc.socket().getLocalPort()));
         SocketChannel s2 = sc.accept() ) {

        test(s1.socket(), s2.socket(), "Testing NIO");
    }

    if (failed) {
        throw new RuntimeException("Failed: check output");
    }
}
 
開發者ID:lambdalab-mirror,項目名稱:jdk8u-jdk,代碼行數:24,代碼來源:ShutdownInput.java

示例10: run

import java.nio.channels.ServerSocketChannel; //導入依賴的package包/類
public void run() {
    try {
        java.nio.channels.Selector acceptSelector = java.nio.channels.Selector.open();
        serverSocketChannel.register(acceptSelector, SelectionKey.OP_ACCEPT);
        while (serverSocketChannel.isOpen()) {
            if (acceptSelector.select(1000) > 0) {
                Iterator<SelectionKey> it = acceptSelector.selectedKeys().iterator();
                while (it.hasNext()) {
                    SelectionKey key = it.next();
                    if (key.isAcceptable()) {
                        SocketChannel socketChannel = ((ServerSocketChannel) key.channel()).accept();
                        socketChannel.configureBlocking(false);
                        newChannels.add(socketChannel);
                        selector.wakeup();
                    }
                    it.remove();
                }
            }
        }
    } catch (IOException e) {
        // ignore
    }
}
 
開發者ID:YMCoding,項目名稱:kafka-0.11.0.0-src-with-comment,代碼行數:24,代碼來源:NioEchoServer.java

示例11: openServerSocket

import java.nio.channels.ServerSocketChannel; //導入依賴的package包/類
public final void openServerSocket(InetAddress address, int tcpPort) throws IOException
{
	final ServerSocketChannel selectable = ServerSocketChannel.open();
	selectable.configureBlocking(false);
	
	final ServerSocket ss = selectable.socket();
	
	if (address != null)
	{
		ss.bind(new InetSocketAddress(address, tcpPort));
	}
	else
	{
		ss.bind(new InetSocketAddress(tcpPort));
	}
	
	selectable.register(_selector, SelectionKey.OP_ACCEPT);
}
 
開發者ID:rubenswagner,項目名稱:L2J-Global,代碼行數:19,代碼來源:SelectorThread.java

示例12: main

import java.nio.channels.ServerSocketChannel; //導入依賴的package包/類
public static void main(String[] args) throws Exception {

        boolean keepAlive = false;
        String prop = System.getProperty("com.sun.CORBA.transport.enableTcpKeepAlive");
        if (prop != null)
            keepAlive = !"false".equalsIgnoreCase(prop);

        DefaultSocketFactoryImpl sfImpl = new DefaultSocketFactoryImpl();
        ORBImpl orb = new ORBImpl();
        orb.set_parameters(null);
        sfImpl.setORB(orb);

        ServerSocketChannel ssc = ServerSocketChannel.open();
        ssc.socket().bind(new InetSocketAddress(0));

        InetSocketAddress isa = new InetSocketAddress("localhost", ssc.socket().getLocalPort());
        Socket s = sfImpl.createSocket("ignore", isa);
        System.out.println("Received factory socket" + s);
        if (keepAlive != s.getKeepAlive())
            throw new RuntimeException("KeepAlive value not honoured in CORBA socket");
    }
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:22,代碼來源:KeepAliveSockets.java

示例13: openSocketForTransferPort

import java.nio.channels.ServerSocketChannel; //導入依賴的package包/類
private void openSocketForTransferPort(int port) throws IOException {

        executor = Utils.getStandardExecService("[ Acceptable ServersThreadPool ] ",
                2,
                10,
                new ArrayBlockingQueue<Runnable>(65500),
                Thread.NORM_PRIORITY - 2);
        ssc = ServerSocketChannel.open();
        ssc.configureBlocking(false);
        FDTSession sess = FDTSessionManager.getInstance().getSession(sessionID);
        ss = ssc.socket();
        String listenIP = config.getListenAddress();
        if (listenIP == null) {
            ss.bind(new InetSocketAddress(port));
        }
        else
        {
            ss.bind(new InetSocketAddress(InetAddress.getByName(listenIP), port));
        }

        sel = Selector.open();
        ssc.register(sel, SelectionKey.OP_ACCEPT);
        sc = ssc.accept();
        config.setSessionSocket(ssc, ss, sc, s, port);
    }
 
開發者ID:fast-data-transfer,項目名稱:fdt,代碼行數:26,代碼來源:FDTSession.java

示例14: main

import java.nio.channels.ServerSocketChannel; //導入依賴的package包/類
public static void main(String[] args) throws Exception {
//            創建ServerSocketChannel,監聽8080端口
        ServerSocketChannel ssc = ServerSocketChannel.open();
        ssc.socket().bind(new InetSocketAddress(8080));
//            設置為非阻塞模式
        ssc.configureBlocking(false);
//            為ssc注冊選擇器
        Selector selector = Selector.open();
        ssc.register(selector, SelectionKey.OP_ACCEPT);
//            創建處理器
        Handler handler = new Handler(1024);
        while (true) {
//            等待請求,每次等待阻塞3s,超過3s後線程繼續向下運行,如果傳入0或者不傳參數將一直阻塞
            if (selector.select(3000) == 0) {
                System.out.println("等待請求超時……");
                continue;
            }
            System.out.println("處理請求……");
//            獲取待處理的SelectionKey
            Iterator<SelectionKey> keyIter = selector.selectedKeys().iterator();
            while (keyIter.hasNext()) {
                SelectionKey key = keyIter.next();
                try {
                    // 接收到連接請求時
                    if (key.isAcceptable()) {
                        handler.handleAccept(key);
                    }
//            讀數據
                    if (key.isReadable()) {
                        handler.handleRead(key);
                    }
                } catch (IOException ex) {
                    keyIter.remove();
                    continue;
                }
//            處理完後,從待處理的SelectionKey迭代器中移除當前所使用的key
                keyIter.remove();
            }
        }
    }
 
開發者ID:tomoncle,項目名稱:JavaStudy,代碼行數:41,代碼來源:NIOSocketTest.java

示例15: main

import java.nio.channels.ServerSocketChannel; //導入依賴的package包/類
public static void main(String[] args) throws Exception {
//    創建ServerSocketChannel,監聽8080端口
        ServerSocketChannel ssc = ServerSocketChannel.open();
        ssc.socket().bind(new InetSocketAddress(8080));
//    設置為非阻塞模式
        ssc.configureBlocking(false);
//    為ssc注冊選擇器
        Selector selector = Selector.open();
        ssc.register(selector, SelectionKey.OP_ACCEPT);
//    創建處理器
        while (true) {
//    等待請求,每次等待阻塞3s,超過3s後線程繼續向下運行,
//    如果傳入0或者不傳參數將一直阻塞
            if (selector.select(3000) == 0) {
                continue;
            }
//    獲取待處理的SelectionKey
            Iterator<SelectionKey> keyIter = selector.selectedKeys().iterator();
            while (keyIter.hasNext()) {
                SelectionKey key = keyIter.next();
//    啟動新線程處理SelectionKey
                new Thread(new HttpHandler(key)).run();
//    處理完後,從待處理的SelectionKey迭代器中移除當前所使用的key
                keyIter.remove();
            }
        }
    }
 
開發者ID:tomoncle,項目名稱:JavaStudy,代碼行數:28,代碼來源:HttpTest.java


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