`
longgangbai
  • 浏览: 7349442 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论
阅读更多

      xSocket是一个易于使用的基于NIO库来构建高性能,可扩展的网络应用。 它支持写入以及服务器端的应用,以直观的方式客户端应用程序。 检测问题,如低水平NIO选择编程,连接池管理,连接超时被封装的xSocket。  

我从它的官网上面下载了两个JAR一个是其核心JAR包xSocket (core) 

另外一个JAR包是:xSocket multiplexed

先掌握其core部分然后再去学习其扩展部分的功能!

 

      随着xSocket你可以编写高性能,可扩展的客户端和服务器组件的自定义协议如SMTP服务器,代理服务器或客户端和服务器组件是一个基于。

      IDataHandler :服务端或者客户端端数据处理类;

     IConnectHandler 服务端或者客户端连接成功是处理操作。  

IIdleTimeoutHandler 请求处理超时才操作。  

IConnectionTimeoutHandler连接超时的操作

IDisconnectHandler 连接断开时的操作

IBlockingConnection 阻塞模式的连接
INonblockingConnection 非阻塞模式的连接

 

 

XSocket的ongoing实例:

服务端数据处理类:

package com.easyway.space.sockets.xsocket;


import java.io.IOException;
import java.nio.BufferUnderflowException;
import java.nio.channels.ClosedChannelException;

import org.xsocket.MaxReadSizeExceededException;
import org.xsocket.connection.IConnectHandler;
import org.xsocket.connection.IConnectionTimeoutHandler;
import org.xsocket.connection.IDataHandler;
import org.xsocket.connection.IDisconnectHandler;
import org.xsocket.connection.IIdleTimeoutHandler;
import org.xsocket.connection.INonBlockingConnection;
/**
 * 服务端定义数据的处理类
 * @author longgangbai
 *
 */
public class ServerHandler implements IDataHandler ,IConnectHandler ,IIdleTimeoutHandler ,IConnectionTimeoutHandler,IDisconnectHandler {

	/**
	 * 即当建立完连接之后可以进行的一些相关操作处理。包括修改连接属性、准备资源、等!
	 * 连接的成功时的操作
	 */
	@Override
	public boolean onConnect(INonBlockingConnection nbc) throws IOException,
			BufferUnderflowException, MaxReadSizeExceededException {
		String  remoteName=nbc.getRemoteAddress().getHostName();
		System.out.println("remoteName "+remoteName +" has connected !");
      		return true;
	}
    /**
     * 即如果失去连接应当如何处理?
     *需要实现 IDisconnectHandler  这个接口
     * 连接断开时的操作
     */
	@Override
	public boolean onDisconnect(INonBlockingConnection nbc) throws IOException {
	   return false;
	}
	/**
	 * 即这个方法不光是说当接收到一个新的网络包的时候会调用而且如果有新的缓存存在的时候也会被调用。而且
     *The onData will also be called, if the connection is closed当连接被关闭的时候也会被调用的!
	 */
	@Override
	public boolean onData(INonBlockingConnection nbc) throws IOException,
			BufferUnderflowException, ClosedChannelException,
			MaxReadSizeExceededException {
		 String data=nbc.readStringByDelimiter("|");
		 nbc.write("--|server:receive data from client sucessful| -----");
		 nbc.flush();
         System.out.println(data);
         return true;
	}
	/**
	 * 请求处理超时的处理事件
	 */
	@Override
	public boolean onIdleTimeout(INonBlockingConnection connection) throws IOException {
		// TODO Auto-generated method stub
		return false;
	}
	/**
	 * 连接超时处理事件
	 */
	@Override
	public boolean onConnectionTimeout(INonBlockingConnection connection) throws IOException {
		// TODO Auto-generated method stub
		return false;
	}

}

 

 

服务端类:

package com.easyway.space.sockets.xsocket;

import java.net.InetAddress;
import java.util.Map;
import java.util.Map.Entry;

import org.xsocket.connection.IServer;
import org.xsocket.connection.Server;
import org.xsocket.connection.IConnection.FlushMode;

/**
 * 采用XSocket通讯的服务端
 * @author longgangbai
 *
 */
public class XSocketServer {
	
	/**设置当前的端口*/
    private static final int PORT = 8014;
    
    public static void main(String[] args) throws Exception {
    	//注意其构造方法有多个。一般是使用这种构造方法出来的!
    	//不过要注意一下java.net.InetAddress这个类的使用在初始化的时候需要捕获异常
    	//可能是这个绑定的主机可能不存在之类的异常即UnknowHostNameException
    	InetAddress address=InetAddress.getByName("localhost");
    	//创建一个服务端的对象
	    IServer srv = new Server(address,PORT,new ServerHandler());
	    //设置当前的采用的异步模式
	    srv.setFlushmode(FlushMode.ASYNC);
	   try{
		   // srv.run(); 
		   // the call will not return
		   // ... or start it by using a dedicated thread
		    srv.start(); // returns after the server has been started
		    System.out.println("服务器" + srv.getLocalAddress() +":"+PORT); 
		    Map<String, Class> maps=srv.getOptions();
		    if(maps!=null){
		    	
		    	for (Entry<String, Class> entry : maps.entrySet()) {
					System.out.println("key= "+entry.getKey()+" value ="+entry.getValue().getName());
				}
		    }
		    System.out.println("日志: " + srv.getStartUpLogMessage());
		    
	   }catch(Exception e){
	        System.out.println(e);
	    }
	   
  }

}

 

 

 

客户端数据处理类:

package com.easyway.space.sockets.xsocket;


import java.io.IOException;
import java.nio.BufferUnderflowException;
import java.nio.channels.ClosedChannelException;

import org.xsocket.MaxReadSizeExceededException;
import org.xsocket.connection.IConnectHandler;
import org.xsocket.connection.IDataHandler;
import org.xsocket.connection.IDisconnectHandler;
import org.xsocket.connection.INonBlockingConnection;
/**
 * 客户端定义数据的处理类
 * @author longgangbai
 *
 */
public class ClientHandler implements IDataHandler ,IConnectHandler ,IDisconnectHandler {

	/**
	 * 连接的成功时的操作
	 */
	@Override
	public boolean onConnect(INonBlockingConnection nbc) throws IOException,
			BufferUnderflowException, MaxReadSizeExceededException {
		String  remoteName=nbc.getRemoteAddress().getHostName();
		System.out.println("remoteName "+remoteName +" has connected !");
       return true;
	}
    /**
     * 连接断开时的操作
     */
	@Override
	public boolean onDisconnect(INonBlockingConnection nbc) throws IOException {
		// TODO Auto-generated method stub
	   return false;
	}
	/**
	 * 
	 * 接收到数据库时候的处理
	 */
	@Override
	public boolean onData(INonBlockingConnection nbc) throws IOException,
			BufferUnderflowException, ClosedChannelException,
			MaxReadSizeExceededException {
		 String data=nbc.readStringByDelimiter("|");
		 nbc.write("--|Client:receive data from server sucessful| -----");
		 nbc.flush();
         System.out.println(data);
         return true;
	}

}

 

 

 

客户端类:

package com.easyway.space.sockets.xsocket;

import java.io.IOException;

import org.xsocket.connection.BlockingConnection;
import org.xsocket.connection.IBlockingConnection;
import org.xsocket.connection.INonBlockingConnection;
import org.xsocket.connection.NonBlockingConnection;
/**
 * 客户端接收服务端信息
 * @author longgangbai
 * IBlockingConnection:这个的话就是不支持事件回调处理机制的!
 *INonBlockingConnection:这个连接支持回调机制
 *
 *非阻塞的客户端是能够支持事件处理的方法的。即如果从网络通道中没有取到想要的数据就会自动退出程序
 */
public class XSocketClient {
	private static final int PORT = 8014;
	public static void main(String[] args) throws IOException {
		   	//采用非阻塞式的连接
		    INonBlockingConnection nbc = new NonBlockingConnection("localhost", PORT, new ClientHandler());
           
		    //采用阻塞式的连接
			//IBlockingConnection bc = new BlockingConnection("localhost", PORT);
		     //一个非阻塞的连接是很容易就变成一个阻塞连接
		    IBlockingConnection bc = new BlockingConnection(nbc);
		   //设置编码格式
		    bc.setEncoding("UTF-8");
            //设置是否自动清空缓存
			bc.setAutoflush(true);
			//向服务端写数据信息
			 for (int i = 0; i < 100; i++) {
				 bc.write(" client | i |love |china !..." +i);
			}
			 //向客户端读取数据的信息
		   byte[] byteBuffers= bc.readBytesByDelimiter("|", "UTF-8");
		   //打印服务器端信息
		   System.out.println(new String(byteBuffers));
		   //将信息清除缓存,写入服务器端
		   bc.flush();
		   bc.close();
	}

}

 

 

代码如上,如有问题,欢迎商讨, 谢谢!

 

分享到:
评论
7 楼 longgangbai 2013-09-21  
caitiancai 写道
longgangbai 写道
zmty123 写道
找到问题了,client发送太快,连接断开了!


断开很正常,我们项目中如果一段时间不连接,就会断开,很正常的

请问怎么保持连接不断开,一直保持(因为服务器随时可能下发的报文)?

断开是客户端断开,不是服务端断开...
6 楼 caitiancai 2013-09-13  
longgangbai 写道
zmty123 写道
找到问题了,client发送太快,连接断开了!


断开很正常,我们项目中如果一段时间不连接,就会断开,很正常的

请问怎么保持连接不断开,一直保持(因为服务器随时可能下发的报文)?
5 楼 night_mare 2011-09-20  
pyk403 写道
不错很好。。
不过我还有一个疑问,就是ServerHandler 在调用ondata的第51行:
nbc.write("--|server:receive data from client sucessful| -----")
是不是要调用ClientHandler 的  ondata方法啊?

我怎么没找到地方有调ClientHandler ?



我觉得应该是由于XSocketClient中使用的是IBlockingConnection阻塞式连接导致无法回调处理机制。
4 楼 longgangbai 2011-05-31  
zmty123 写道
找到问题了,client发送太快,连接断开了!


断开很正常,我们项目中如果一段时间不连接,就会断开,很正常的
3 楼 zmty123 2011-04-23  
找到问题了,client发送太快,连接断开了!
2 楼 zmty123 2011-04-23  
要发送到service100次数据,发送几次后就断开连接了是为什么!
并且,我修改client发送一次数据,就接收一次数据,
  //向客户端读取数据的信息  
           byte[] byteBuffers= bc.readBytesByDelimiter("|", "UTF-8");  
           //打印服务器端信息  
           System.out.println(new String(byteBuffers));
也接收不到消息!
请问这是为什么!
1 楼 pyk403 2011-03-03  
不错很好。。
不过我还有一个疑问,就是ServerHandler 在调用ondata的第51行:
nbc.write("--|server:receive data from client sucessful| -----")
是不是要调用ClientHandler 的  ondata方法啊?

我怎么没找到地方有调ClientHandler ?

相关推荐

    xsocket源码和socket源码,文档

    总之,这个资源包为你提供了一个很好的学习平台,通过实践和研究源码,你将能够深入理解Socket和XSocket编程,进一步提升你的网络编程技能。记得要结合理论知识和实际操作,才能更好地消化和掌握这些内容。

    xSocket api 2.6.6version

    xSocket api 2.6.6version

    NIO网络框架 xSocket

    NIO网络框架 xSocket

    xsocket NIO框架示例

    xsocket NIO框架示例 resources 中有相关的 资料。telnet服务测试教程。和相关jar

    ws(websocket)例子(xsocket\xlightweb)

    总结来说,这个压缩包提供的示例可能包括了如何使用xsocket和xlightweb库在服务器端和客户端实现WebSocket通信的具体代码。通过学习这些示例,开发者可以更好地理解WebSocket的工作原理,以及如何在实际项目中应用这...

    tcp协议使用xsocket的demo

    "tcp协议使用xsocket的demo"是一个实践性强、教学价值高的项目,它涵盖了SpringBoot、TCP通信和模块化开发等多个核心知识点,对于想要深入了解Java网络编程和SpringBoot集成的开发者来说,这是一个极好的学习资源。

    xsocket 2.5.4 源代码

    xSocket-2.5.4-sources.jar , 2.5.4版的源代码jar包,引入项目即可查看

    XSocket.rar

    总的来说,XSocket.rar文件提供了关于Socket编程、TCP/IP协议实现、客户端和服务器端交互以及多播功能的实战示例,对于学习和开发网络通信应用的程序员来说,这是一个宝贵的资源。通过研究这个项目,开发者可以深入...

    xsocket.jar包

    socket通讯框架xsocket所需的jar包

    xsocket使用指南

    下面是 xSocket 的一些核心功能和使用指南: 核心功能 xSocket 的核心功能支持面向流通信,主要抽象是 Connection 接口。通过 IBlockingConnection 或者 INonblockingConnection 对象进行数据的读写。在 record ...

    xSocket-2.8.1.jar

    xSocket是一个轻量级的基于nio的服务器框架用于开发高性能、可扩展、多线程的服务器。该框架封装了线程处理、异步读/写等方面。

    轻量级JAVA scoket 服务器XSOCKET

    轻量级JAVA scoket 服务器XSOCKET

    java源码:NIO网络框架 xSocket.rar

    Java NIO(New Input/Output)网络框架是一...通过学习和使用xSocket框架,开发者可以更好地理解和应用Java NIO,创建出高效、可靠的网络应用程序。在实际开发中,结合NIO的特性,可以显著提升网络应用的性能和稳定性。

    常见NIO开源框架(MINA、xSocket)学习

    常见NIO开源框架(MINA、xSocket)学习 基于io包的阻塞式socket通信代码简单,在连接数很少的情况下是一个不错的选择。不过实际应用中一个socket服务器采用传统的阻塞式socket方式通信可能会是一场灾难,一路...

    xsocket.7z

    它通过抽象出统一的API,隐藏了底层操作系统差异,降低了开发者的学习曲线和维护成本。 XSocket的核心特性在于其对Socket操作的封装。在C语言原生的Socket API中,开发者需要处理许多低级别的细节,如错误检查、套...

    xSocket sources

    提到的三个文件分别代表了xSocket的不同版本:`xSocket-2.1.2-sources.jar` 包含的是2.1.2版本的源代码,这对于学习和调试非常有用;`xSocket-2.7.2.jar` 可能是一个更新的二进制版本,可能包含了更多的功能和优化...

    NIO网络框架 xSocket.7z

    3. 文档资料:包含了框架的使用指南、API文档以及设计原理等,帮助开发者更好地学习和使用xSocket。 4. 测试用例:验证框架功能的正确性,可作为开发过程中参考和调试的依据。 5. 配置文件:可能包含服务器配置、...

    基于java的开发源码-NIO网络框架 xSocket.zip

    基于java的开发源码-NIO网络框架 xSocket.zip 基于java的开发源码-NIO网络框架 xSocket.zip 基于java的开发源码-NIO网络框架 xSocket.zip 基于java的开发源码-NIO网络框架 xSocket.zip 基于java的开发源码-NIO网络...

    xSocket-multiplexed-2.1.5-sources.jar

    xSocket-multiplexed-2.1.5-sources.jarxSocket-multiplexed-2.1.5-sources.jarxSocket-multiplexed-2.1.5-sources.jarxSocket-multiplexed-2.1.5-sources.jarxSocket-multiplexed-2.1.5-sources.jarxSocket-...

Global site tag (gtag.js) - Google Analytics