java nio socket 服务端开发 demo

直接上代码


//服务端
import java.io.IOException;
import java.net.InetSocketAddress;
import java.nio.ByteBuffer;
import java.nio.channels.SelectionKey;
import java.nio.channels.Selector;
import java.nio.channels.ServerSocketChannel;
import java.nio.channels.SocketChannel;
import java.util.Iterator;

import org.apache.log4j.Logger;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.util.StringUtils;

import com.haople.manager.lockset.socket.util.DataUtil;


public class SocketServer {
	private static final Logger logger=Logger.getLogger(SocketServer.class);
	@Value("${server_addr}")
	private String serverAddr;
	@Value("${socket_port}")
	private Integer port;
    private Selector selector;
	
	public void start() throws IOException {
			logger.info("正在启动socket服务");
			ServerSocketChannel serverSocketChannel = ServerSocketChannel.open();
			serverSocketChannel.socket().bind(new InetSocketAddress(serverAddr,port)); // 绑定本地端口
			serverSocketChannel.configureBlocking(false); // 设置通道为非阻塞
	        selector=Selector.open();
	        serverSocketChannel.register(selector, SelectionKey.OP_ACCEPT);
			logger.info("启动socket服务--[ "+serverAddr+" : "+port+" ]--成功!");
			while(true){
	            selector.select();
	            Iterator<SelectionKey> ite=selector.selectedKeys().iterator();
	            while(ite.hasNext()){
	            	 SelectionKey key = ite.next();
	                 ite.remove();
	                 if (key.isAcceptable()) {
				ServerSocketChannel ssc = (ServerSocketChannel) key.channel();
				SocketChannel sc = ssc.accept();
				logger.info("客户端机子的地址是 "+sc.socket().getRemoteSocketAddress()+ "  客户端机机子的端口号是 "+ sc.socket().getLocalPort());
				sc.configureBlocking(false);
				sc.register(selector, SelectionKey.OP_READ);
			}
	                 else if(key.isReadable()){
	                	 recive(key);
	                 }
	            }
			}
	}
	
	public void recive(SelectionKey key){
		SocketChannel sc = (SocketChannel) key.channel();
		try {
			ByteBuffer dst=ByteBuffer.allocate(5*1024);//5K
			dst.clear();
			ByteBuffer readBuffer = ByteBuffer.allocate(1024); 
			readBuffer.clear();
			while(true){
				int bytesRead=sc.read(readBuffer);
				if(bytesRead>0){
					readBuffer.flip();
					dst.put(readBuffer);
					readBuffer.clear();
				}else{
					break;
				}
			}
			dst.flip();
			String  request=new String(dst.array());
			logger.info("接收数据:"+request);
			String response="hello word";
				ByteBuffer writeBuffer=ByteBuffer.wrap(DataUtil.encodeUTF(response));
				sc.write(writeBuffer);
		} catch (IOException e) {
			logger.info("--处理异常--",e);
		}
	}
	
	
	
}

 

客户端:
方法:
public void start() {
		try {
			SocketChannel socketChannel=SocketChannel.open();
			boolean flag=socketChannel.connect(new InetSocketAddress("127.0.0.1",8888));
			String res="hello service";
			System.err.println("发送-:"+res);
			byte[] bs1=DataUtil.encodeUTF(res);
			ByteBuffer writeBuffer=ByteBuffer.wrap(bs1);
			socketChannel.write(writeBuffer);
		        ByteBuffer buffer = ByteBuffer.allocate(100);
	                socketChannel.read(buffer);
                        byte[] data = buffer.array();
                        String message = new String(data);
                        System.out.println("recevie message from server:, size:" + buffer.position() + " msg: " + message);
			socketChannel.close();
		} catch (IOException e) {
			e.printStackTrace();
		} 
	}

 

转载于:https://my.oschina.net/haopeng/blog/666498

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值