nio server


import java.net.InetSocketAddress;
import java.net.Socket;
import java.nio.ByteBuffer;
import java.nio.CharBuffer;
import java.nio.channels.SelectionKey;
import java.nio.channels.Selector;
import java.nio.channels.ServerSocketChannel;
import java.nio.channels.SocketChannel;
import java.nio.charset.Charset;
import java.nio.charset.CharsetDecoder;
import java.nio.charset.CharsetEncoder;
import java.util.Iterator;

public class X {

 /**
  * @param args
  */
 public static void main(String[] args) {
  // TODO Auto-generated method stub
    String[] strs = null;
    Selector selector = null;
    try {
     selector = Selector.open();
     ServerSocketChannel server = ServerSocketChannel.open();
     server.socket().bind(new InetSocketAddress(8080));
     server.configureBlocking(false);
     server.register(selector, SelectionKey.OP_ACCEPT);
    } catch (Exception e) {
     e.printStackTrace();
     System.exit(1);
    }
    
    int index = 0;
    SelectionKey key = null;
    
    Charset charset = Charset.forName("UTF-8");
    CharsetEncoder encoder = charset.newEncoder();
    CharsetDecoder decoder = charset.newDecoder();
    CharBuffer charBuffer = CharBuffer.allocate(1024);
    ByteBuffer buffer = ByteBuffer.allocate(1024 * 10);
    StringBuffer sBuffer = new StringBuffer();
    
    while(true) {
     try {
      index = selector.select();
      if(index > 0) {
       Iterator it = selector.selectedKeys().iterator();
       
       while(it.hasNext()) {
        key = (SelectionKey) it.next();
        it.remove();
        
        if(key.isValid()) {
         if(key.isAcceptable()) {
          System.out.println("accept ... ");
          Socket socket = ((ServerSocketChannel)key.channel()).accept().socket();
          SocketChannel sc = socket.getChannel();
          sc.configureBlocking(false);
          sc.register(key.selector(), SelectionKey.OP_READ);
         } else if(key.isReadable()) {
          System.out.println("read ... ");
          SocketChannel sc = (SocketChannel) key.channel();

          while(sc.read(buffer) > 0) {
           buffer.flip();
           decoder.decode(buffer, charBuffer, false);
           charBuffer.flip();
           sBuffer.append(charBuffer).append("/r/n");
           //System.out.println(charBuffer);
           buffer.clear();
           charBuffer.clear();
          }
          buffer.flip();
          strs = sBuffer.toString().split("/r/n");
          sc.configureBlocking(false);
          sc.register(key.selector(), SelectionKey.OP_WRITE);
         } else if(key.isWritable()) {
          System.out.println("write ... ");
          SocketChannel sc = (SocketChannel) key.channel();
          
          if(strs != null) {
           charBuffer.clear();
           charBuffer.flip();
           System.out.println("length:"+strs.length);
           for(int i=0;i<strs.length;i++) {
            sc.write(encoder.encode(charBuffer.wrap(strs[i]+"/r/n")));
            //sc.write(encoder.encode(charBuffer.wrap("Hello/r/n")));
            System.out.println(charBuffer);
            charBuffer.clear();
            charBuffer.flip();
           }
           //sc.write(encoder.encode(charBuffer.wrap("/r/n")));
           charBuffer.clear();
           charBuffer.flip();
          }
          sc.finishConnect();
          sc.close();
         }
        }
       }
      }
     } catch (Exception e) {
      e.printStackTrace();
      System.exit(1);
     }
    }
 }

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java NIO (New IO) 是Java SE 1.4引入的一个新的IO API,可以用来替代Java标准IO和Java网络编程中的SocketServerSocket。Java NIO提供了非阻塞式的IO操作,可以实现更高效的网络编程。 以下是Java NIO的一个使用案例: ```java import java.io.IOException; import java.net.InetSocketAddress; import java.nio.ByteBuffer; import java.nio.channels.ServerSocketChannel; import java.nio.channels.SocketChannel; import java.util.Scanner; public class NIOServer { public static void main(String[] args) throws IOException { // 创建ServerSocketChannel并绑定端口 ServerSocketChannel serverSocketChannel = ServerSocketChannel.open(); serverSocketChannel.socket().bind(new InetSocketAddress(9999)); serverSocketChannel.configureBlocking(false); System.out.println("NIOServer started on port 9999"); // 创建一个ByteBuffer用于读取数据 ByteBuffer buffer = ByteBuffer.allocate(1024); while (true) { // 接收客户端连接 SocketChannel socketChannel = serverSocketChannel.accept(); if (socketChannel != null) { System.out.println("Client connected from " + socketChannel.getRemoteAddress()); // 读取客户端发送的数据 int bytesRead = socketChannel.read(buffer); while (bytesRead != -1) { buffer.flip(); while (buffer.hasRemaining()) { System.out.print((char) buffer.get()); } buffer.clear(); bytesRead = socketChannel.read(buffer); } socketChannel.close(); } // 处理控制台输入 Scanner scanner = new Scanner(System.in); String message = scanner.nextLine(); if (message.equals("quit")) { break; } } // 关闭ServerSocketChannel serverSocketChannel.close(); } } ``` 该程序实现了一个简单的NIO服务器,它监听9999端口,接收客户端连接并读取客户端发送的数据。程序通过一个无限循环来保持运行,可以通过控制台输入"quit"来退出程序。在程序运行过程中,可以使用telnet命令来模拟客户端连接并发送数据: ``` telnet localhost 9999 ``` 输入数据后,按下Enter键,然后可以在服务器控制台上看到客户端发送的数据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值