摘要: Socket通信几乎无时不在, 当然能够搜集到的信息也大量存在, 为了避免重复的劳作, 抽取了关于客户端和服务端的Socket, 并将其应用到适合JVM(LInux/Windows)或者DVM(Android)平台. 这个封装好的API具有以下优势:
1. 满足具有Socket客户端需求的基本应用.
2. 满足具有Socket服务端的基本应用. 具备并发能力, 能满足可设定个数客户端连接.
本文的目的就是为了对Socket做一个封装, 方便客户端和服务端能直接使用Socket.
封装好的API可以从下面的链接获取
[url]Java Socket的封装[/url]
http://download.csdn.net/download/ostrichmyself/3477439
其中src/中的是API源码; usage/目录是使用例程
1客户端Socket API
要点:
1. 客户端和指定的服务端相连, 因此客户端需要指明服务端对应的IP地址和端口号
2. 需要设置超时返回
3. 需要设置循环等待, 因为基本的Socket通信都是一来一回, 这种来回是通过阻塞来完成的。
4. 每个客户端连入服务端的时候, 都具备本身的ID, 类似于HTTP的Session, 这点容易被忽视。在多客户端连接中, 可以重点关注。本文提供的代码也有所提及, 但没有深入, 这点留给读者进一步发掘。
代码参照/usage目录下的客户端测试代码, 注意, 先启动服务端,或者你拿着NetAssis 来测试也不错.
2 服务端Socket API
要点:
1. 服务端一般是被多个客户端连接的, 并且这些连接要求服务端做相似的处理, 因此这里就将这些相似处理, 抽象成一个SingleTask.java 接口, 具体的业务只需要实现这样的接口, 就可以并行的处理这些Task.
2. 不能无限制的让客户端连入Server, 因此需要设置上限值
3. 启动线程池, 每个线程针对一个具体的客户端连接
4. 注意接收阻塞位置, 需要设置死循环, 读不到数据将死守着等待(但别耽误其它线程处理事情)
5. 注意服务端要在死循环中侦听, 这样保证不错过任何来自客户端的请求。
代码参照:/usage目录下的Server端测试代码。
代码中注释很多,因此这里就不详细述说。
常见问题:
1. 客户端Client的时候, 如果存在网络问题, 为了避免网络问题,造成客户端长时间等待, 此时要设置一个TimeOut
clientSocket = new Socket();
//这个TimeOut是连接等待时间
clientSocket.connect(tcpAddress, timeOut);
2. 当客户端已经连接, 每次收到一个数据, 客户端将启动处理, 假如服务器长久不发数据, 此时客户端会阻塞等待, 为了避免这个时候的等待, 可以设置一个超时
clientSocket.setSoTimeout(timeOut);
参考文献:
参考工具: NetAssis 使用这个工具用来测试C-S之间的通信.
转自:http://blog.csdn.net/ostrichmyself/article/details/6618349
分享到:
相关推荐
Socket通信客户端封装包 对事件进行封装 可以接收大量数据
socket封装库,有服务器和客户端,客户端和服务器集于一体,可以相互发送消息。
C# socket封装类和组件含例程全部开源,可以说全网封装最好的C#类,十分强大,亲测很好,值得参考和学习
Socket 客户端代码封装、服务端代码封装,让使用Socket更简单,队列处理,带使用实例。
1. 满足具有Socket客户端需求的基本应用. 2. 满足具有Socket服务端的基本应用. 具备并发能力, 能满足可设定个数客户端连接. 参考个人博客: http://blog.csdn.net/ostrichmyself/article/details/6618349
c#Socket客户端断线重连封装类(可直接调用).rar
Socket 客户端代码封装、服务端代码封装,让使用Socket更简单。 同时服务端支持超过客户端连接(测试超过1万个同时连接稳定运行),Tasks多线程 队列处理 大数据拆分包处理
vc socket封装类通讯CAsyncSocket,支持多客户端连接,通讯。
MFC编写的TCP协议的socket客户端服务器程序代码
主要介绍了C++自定义封装socket操作业务类,结合完整实例形式分析了Linux环境下C++操作socket的封装业务类,可实现基本的socket连接、参数设置、发送请求等基本功能,需要的朋友可以参考下
C# socket封装类和组件含例程源代码,值得参考和学习
Android tcp socket通信封装及实例 1、模拟器上和电脑上开的sokit服务端通信测试通过 2、下载sokit当服务端
所以我对socket进行了封装,客户端和服务端可以通过配置注解,让双方相互调用注解方法,提供了专门的工具类,让注解方法可以支持返回list或map等集合或其他的类型,三行代码你就可以完美的使用socket进行通信,支持...
Python 通过 socket 实现服务端和客户端相互间网络通信的例子 通过socket实现网络通信 通过thread多线程实现同时收发
通过使用Socket类,开发人员可以创建客户端和服务器端应用程序,并实现它们之间的双向通信。 使用Socket类进行网络编程的基本模式是: 创建一个Socket对象,并指定要使用的协议类型(如TCP或UDP)。 使用Socket...
易学,易掌握,简单,易学,易掌握,简单,易学,易掌握,简单,易学,易掌握,简单,易学,易掌握,简单,易学,易掌握,简单,易学,易掌握,简单,易学,易掌握,简单,易学,易掌握,简单,易学,易掌握,简单,
1.采用重叠I/O方式实现的socket网络编程,异步非阻塞方式,代码效率比阻塞式的socket编程方式高。2.实现了TCP server方式,只用于服务端,可以支持多客户端。3.可以使用在各种场合用于监控网络数据。4.代码封装成库...
使用socket channel 连接服务器,断线重连,发送保活等的封装类。 Java NIO中的SocketChannel是一个连接到TCP网络套接字的通道。可以通过以下2种方式创建SocketChannel: 打开一个SocketChannel并连接到互联网上的...
使用IOCP完成端口和SOCKET封装的异步TCP类。 支持客户端和服务器的常用TCP接口:绑定Bind、监听Listen、接收Recv、连接Conn、发送Send、关闭Close。所有接口均使用异步回调的方式处理,内部实现使用Windows下性能...
C写的客户端 封装了发送和接收的函数 和我上传的服务端是一套 SOCKET客户端 发送数据例子 C写的客户端 封装了发送和接收的函数 和我上传的服务端是一套 SOCKET客户端 发送数据例子