- 浏览: 224447 次
- 性别:
- 来自: 上海
文章分类
最新评论
-
kandari:
很全,收藏
oracle相关知识 -
若见三生石:
,辛苦楼主!感谢为大伙敏捷开发做出贡献!
Oracle中的二进制、八进制、十进制、十六进制相互转换函数 -
若见三生石:
你好,要定义的类和类型怎么写呢?
Oracle中的二进制、八进制、十进制、十六进制相互转换函数 -
greatwqs:
...
PLSQL操作文件 -
sun17921:
var areaCode ={11:"北京" ...
身份证验证JS
第一步 充分理解Socket
1.什么是socket
所谓socket通常也称作"套接字",用于描述IP地址和端口,是一个通信链的句柄。应用程序通常通过"套接字"向网络发出请求或者应答网络请求。
以J2SDK-1.3为例,Socket和ServerSocket类库位于java.net包中。ServerSocket用于服务器端,Socket是建立网络连接时使用的。在连接成功时,应用程序两端都会产生一个Socket实例,操作这个实例,完成所需的会话。对于一个网络连接来说,套接字是平等的,并没有差别,不因为在服务器端或在客户端而产生不同级别。不管是Socket还是ServerSocket它们的工作都是通过SocketImpl类及其子类完成的。
重要的Socket API:
java.net.Socket继承于java.lang.Object,有八个构造器,其方法并不多,下面介绍使用最频繁的三个方法,其它方法大家可以见JDK-1.3文档。
.Accept方法用于产生"阻塞",直到接受到一个连接,并且返回一个客户端的Socket对象实例。"阻塞"是一个术语,它使程序运行暂时"停留"在这个地方,直到一个会话产生,然后程序继续;通常"阻塞"是由循环产生的。
.getInputStream方法获得网络连接输入,同时返回一个IutputStream对象实例,。
.getOutputStream方法连接的另一端将得到输入,同时返回一个OutputStream对象实例。
注意:其中getInputStream和getOutputStream方法均会产生一个IOException,它必须被捕获,因为它们返回的流对象,通常都会被另一个流对象使用。
2.如何开发一个Server-Client模型的程序
开发原理:
服务器,使用ServerSocket监听指定的端口,端口可以随意指定(由于1024以下的端口通常属于保留端口,在一些操作系统中不可以随意使用,所以建议使用大于1024的端口),等待客户连接请求,客户连接后,会话产生;在完成会话后,关闭连接。
客户端,使用Socket对网络上某一个服务器的某一个端口发出连接请求,一旦连接成功,打开会话;会话完成后,关闭Socket。客户端不需要指定打开的端口,通常临时的、动态的分配一个1024以上的端口。
import java.net.*; import java.io.*; public class Server { private ServerSocket ss; private Socket socket; private BufferedReader in; private PrintWriter out; public Server() { try { ss = new ServerSocket(10000); while (true) { socket = ss.accept(); in = new BufferedReader(new InputStreamReader(socket .getInputStream())); out = new PrintWriter(socket.getOutputStream(), true); String line = in.readLine(); out.println("you input is :" + line); out.close(); in.close(); socket.close(); } ss.close(); } catch (IOException e) { } } public static void main(String[] args) { new Server(); } }
这个程序建立了一个服务器,它一直监听10000端口,等待用户连接。在建立连接后给客户端返回一段信息,然后结束会话。这个程序一次只能接受一个客户连接。
import java.io.*; import java.net.*; public class Client { Socket socket; BufferedReader in; PrintWriter out; public Client() { try { socket = new Socket("xxx.xxx.xxx.xxx", 10000); in = new BufferedReader(new InputStreamReader(socket .getInputStream())); out = new PrintWriter(socket.getOutputStream(), true); BufferedReader line = new BufferedReader(new InputStreamReader( System.in)); out.println(line.readLine()); line.close(); out.close(); in.close(); socket.close(); } catch (IOException e) { } } public static void main(String[] args) { new Client(); } }
这个客户端连接到地址为xxx.xxx.xxx.xxx的服务器,端口为10000,并从键盘输入一行信息,发送到服务器,然后接受服务器的返回信息,最后结束会话。
第二步 多个客户同时连接
在实际的网络环境里,同一时间只对一个用户服务是不可行的。一个优秀的网络服务程序除了能处理用户的输入信息,还必须能够同时响应多个客户端的连接请求。在java中,实现以上功能特点是非常容易的。
设计原理:
主程序监听一端口,等待客户接入;同时构造一个线程类,准备接管会话。当一个Socket会话产生后,将这个会话交给线程处理,然后主程序继续监听。运用Thread类或Runnable接口来实现是不错的办法。
import java.io.*; import java.net.*; public class Server extends ServerSocket { private static final int SERVER_PORT = 10000; public Server() throws IOException { super(SERVER_PORT); try { while (true) { Socket socket = accept(); new CreateServerThread(socket); } } catch (IOException e) { } finally { close(); } } // --- CreateServerThread class CreateServerThread extends Thread { private Socket client; private BufferedReader in; private PrintWriter out; public CreateServerThread(Socket s) throws IOException { client = s; in = new BufferedReader(new InputStreamReader(client .getInputStream(), "GB2312")); out = new PrintWriter(client.getOutputStream(), true); out.println("--- Welcome ---"); start(); } public void run() { try { String line = in.readLine(); while (!line.equals("bye")) { String msg = createMessage(line); out.println(msg); line = in.readLine(); } out.println("--- See you, bye! ---"); client.close(); } catch (IOException e) { } } private String createMessage(String line) { xxxxxxxxx; } } public static void main(String[] args) throws IOException { new Server(); } }
这个程序监听10000端口,并将接入交给CreateServerThread线程运行。CreateServerThread线程接受输入,并将输入回应客户,直到客户输入"bye",线程结束。我们可以在createMessage方法中,对输入进行处理,并产生结果,然后把结果返回给客户
第三步 实现信息共享:在Socket上的实时交流
网络的伟大之一也是信息共享,Server可以主动向所有Client广播消息,同时Client也可以向其它Client发布消息。下面看看如何开发一个可以实时传递消息的程序。
设计原理:
服务器端接受客户端的连接请求,同时启动一个线程处理这个连接,线程不停的读取客户端输入,然后把输入加入队列中,等候处理。在线程启动的同时将线程加入队列中,以便在需要的时候定位和取出。
import java.io.*; import java.net.*; import java.util.*; public class Server extends ServerSocket { private static ArrayList User_List = new ArrayList(); private static ArrayList Threader = new ArrayList(); private static LinkedList Message_Array = new LinkedList(); private static int Thread_Counter = 0; private static boolean isClear = true; protected static final int SERVER_PORT = 10000; protected FileOutputStream LOG_FILE = new FileOutputStream( "d:/connect.log", true); public Server() throws FileNotFoundException, IOException { super(SERVER_PORT); new Broadcast(); // append connection log Calendar now = Calendar.getInstance(); String str = "[" + now.getTime().toString() + "] Accepted a connection\015\012"; byte[] tmp = str.getBytes(); LOG_FILE.write(tmp); try { while (true) { Socket socket = accept(); new CreateServerThread(socket); } } finally { close(); } } public static void main(String[] args) throws IOException { new Server(); } // --- Broadcast class Broadcast extends Thread { public Broadcast() { start(); } public void run() { while (true) { if (!isClear) { String tmp = (String) Message_Array.getFirst(); for (int i = 0; i < Threader.size(); i++) { CreateServerThread client = (CreateServerThread) Threader .get(i); client.sendMessage(tmp); } Message_Array.removeFirst(); isClear = Message_Array.size() > 0 ? false : true; } } } } // --- CreateServerThread class CreateServerThread extends Thread { private Socket client; private BufferedReader in; private PrintWriter out; private String Username; public CreateServerThread(Socket s) throws IOException { client = s; in = new BufferedReader(new InputStreamReader(client .getInputStream())); out = new PrintWriter(client.getOutputStream(), true); out.println("--- Welcome to this chatroom ---"); out.println("Input your nickname:"); start(); } public void sendMessage(String msg) { out.println(msg); } public void run() { try { int flag = 0; Thread_Counter++; String line = in.readLine(); while (!line.equals("bye")) { if (line.equals("l")) { out.println(listOnlineUsers()); line = in.readLine(); continue; } if (flag++ == 0) { Username = line; User_List.add(Username); out.println(listOnlineUsers()); Threader.add(this); pushMessage("[< " + Username + " come on in >]"); } else { pushMessage("<" + Username + ">" + line); } line = in.readLine(); } out.println("--- See you, bye! ---"); client.close(); } catch (IOException e) { } finally { try { client.close(); } catch (IOException e) { } Thread_Counter--; Threader.remove(this); User_List.remove(Username); pushMessage("[< " + Username + " left>]"); } } private String listOnlineUsers() { String s = "-+- Online list -+-\015\012"; for (int i = 0; i < User_List.size(); i++) { s += "[" + User_List.get(i) + "]\015\012"; } s += "-+---------------------+-"; return s; } private void pushMessage(String msg) { Message_Array.addLast(msg); isClear = false; } } }
发表评论
-
spring事件驱动
2014-03-07 00:53 613http://jinnianshilongnian.ite ... -
Java NIO API
2012-02-23 08:52 936http://www.blogjava.net/1985198 ... -
Threadlocal提供一个独立的变量副本
2012-02-21 14:15 1187ThreadLocal是解决线程安全问题一个很好的思 ... -
MD5 Base64
2012-02-03 11:09 1118哈希函数:MD5,SHA 是没有密钥的,相当与指纹的概念,因此 ... -
HTTP详细描述
2012-02-01 09:00 815原文:http://www.cnblogs.com ... -
include与jsp:include区别
2012-02-01 08:58 920一:执行时间上: <%@ include fi ... -
Java深复制与浅复制&Clone
2011-07-21 09:42 835http://zzqrj.iteye.com/blog/572 ... -
session与cookie
2010-04-23 14:32 745一、cookie机制和session机制的区别 具体来说 ... -
OGNL“valueStack”
2009-12-30 16:21 977详细例子:http://www.iteye.com/wiki/ ... -
servlet单实例多线程
2009-12-23 22:36 2022一,servlet容器如何同时处理多个请求。 Servlet ... -
JDBC事务、JTA事务
2009-12-23 22:27 1461一般情况下,J2EE应用服务器支持JDBC事务、JTA事务、容 ... -
forword的redirect属性
2009-12-23 20:57 1770Forward高, Redirect低, 因为Redirec ... -
JDBC连接数据库
2009-12-23 18:21 782使用JDBC连接数据库的步骤如下: (1)首先要在应用程序中 ... -
final和static
2009-12-23 18:05 1156一、final 根据程序上下 ... -
log4j详述
2009-12-18 10:09 687http://www.iteye.com/topic/3780 ... -
java文件上传(Cos和FileUpload和SmartUpload)
2009-12-15 21:28 3501SmartUpload上传专题:http://thousa ... -
IS08583报文协议(理论)
2009-12-12 17:11 1266单纯的讲IS08583 ... -
java Socket透析http协议
2009-12-12 14:38 1559WWW是以Internet作为传输媒介的一个应用系统,WWW网 ... -
socket理论
2009-12-12 14:22 9161.什么是socket 所谓socket ... -
JKD1.5的多线程启动socket实例
2009-12-11 10:17 1076import java.io.*; import java. ...
相关推荐
Socket编程是计算机网络编程中的重要组成部分,主要用于实现客户端与服务器之间的通信。在这个“socket实现实时消息发送...通过这些技术的结合,我们可以构建一个高效、可靠的实时消息系统,支持文字和图片的双向交流。
在IT行业中,即时通讯(Instant Messaging,简称IM)是一种常见的技术,它允许用户实时地进行文本、语音甚至视频交流。在本案例中,我们将聚焦于使用C#编程语言和WinForms来实现基于Socket的即时通讯系统。Socket是...
这样,双方就可以通过socket进行实时交流了。 在这个案例中,文件"socket服务端客户端互聊"可能包含了服务器端和客户端的完整代码示例,通过运行这些程序,初学者可以直观地理解socket通信的过程。实践中,可以将...
socket_write ( $newsock , "这是一个delphi(客户端) socket 与 PHP_socket(服务器) 通信的例子 测试,交流QQ:410578660。 but ill make an exception :)\n" . "There are " .( count ( $clients ) - 1 ). " ...
在这个示例代码中,我们使用了 sockaddr_in 结构体来设置服务器端的地址和端口,然后使用 socket 函数创建一个 Socket,接着使用 bind 函数将本地地址绑定到所创建的套接字上,最后使用 listen 函数对端口进行监听。...
这是小例子是我自学Socket编程的时候写的,没有太大的扩展性,因为里面用的分隔符我一直没有想到太好的,所以用,号分割了,聊天的时候不能发,号 要么会出错,大家可以下载之后自己改,我觉得还算能用!很久没有发表...
在这个“android实现Socket通信聊天Demo”项目中,开发者创建了一个简单的聊天室,让用户能够通过Socket进行实时交流。 首先,我们要理解TCP协议。TCP(Transmission Control Protocol)是互联网协议族中的传输层...
而Socket.IO则是在Node.js之上构建的一个强大的库,不仅提供了WebSocket的完整实现,还支持多种回退方案以确保良好的兼容性。 - **Node.js的优势**: - **异步非阻塞I/O**:这使得Node.js能够高效处理大量并发连接...
总结,这个基于 Socket.IO 的聊天室项目提供了一个基础的实时交流平台。通过学习和改进,可以将其扩展为功能更完善的聊天应用,例如添加私信、表情、文件发送等功能,并优化用户界面和体验,提高系统的稳定性和安全...
在IT行业中,网络编程是构建分布式系统的关键技术之一,而Socket接口是实现网络通信的基础。本教程将聚焦于Linux环境下的Socket编程,讲解如何通过C语言实现简单的客户端与服务端的交互,主要涉及TCP(Transmission ...
通过创建Socket,一个程序能够发送和接收数据,就像是在网络上的两个端点之间建立了一个通道。 在标题中提到的"基于socket的网络编程技术",主要指的是使用Socket API来实现网络通信功能。在本例中,是利用Socket来...
标签中的"聊天编程"表明我们要构建的是一个交互式的系统,用户可以与其他用户进行实时交流。在实际开发中,可能还需要考虑用户认证、消息序列化、错误处理、断线重连等功能。此外,为了提高用户体验,可以引入GUI...
通过TServerSocket和TClientSocket进行Socket通信,使用SQLite3存储数据,以及自定义类和数组优化程序结构,实现了用户之间的实时交流。对于想要学习Delphi网络编程和数据库集成的开发者来说,这是一个很好的实践...
"世界语"(交流的语言很重要)意味着不同的操作系统和编程语言可能有不同的Socket API,但基本概念和原理是相似的。了解这些基本概念后,你就可以进一步学习如何处理更复杂的Socket编程问题,例如多线程、异步I/O、...
3. 发送和接收数据:使用Send和Receive方法在Socket上发送和接收数据。通常,需要在一个循环中执行,以便不断接收和处理来自客户端的消息。 4. 创建ClientSocket:在客户端,创建Socket实例,使用Connect方法连接到...
在这个过程中,一个计算机上的Socket作为服务器端,监听特定端口上的连接请求,而另一计算机上的Socket作为客户端,发起连接请求。 对于“多人聊天”应用,我们需要构建一个服务端(Server)来监听和管理多个客户端...
1. **Socket基本概念**:Socket是TCP/IP协议的一部分,它提供了一种在互联网上两台计算机之间进行数据传输的接口。在C#中,System.Net.Sockets命名空间提供了Socket类,用于实现基于TCP或UDP的网络通信。 2. **TCP...
在这个实验中,我们将使用Socket API在C-S模式下构建一个可以相互交流的客户端。 Socket是Internet协议族的一部分,它提供了一种标准的接口,使得应用程序能够通过TCP/IP协议进行数据传输。TCP(Transmission ...
在这个"Socket实现简单聊天室功能"的例子中,我们将会深入理解如何利用Socket来创建一个基本的聊天应用,使两台或多台电脑能够进行实时交互。 首先,我们需要了解Socket的基本概念。Socket可以被看作是网络上的端点...
在本文中,我们将深入...通过这种方式,服务器可以有效地管理并服务多个客户端,实现信息的实时交流。这个简单聊天系统的实现,不仅展示了C#的网络编程能力,也为我们提供了基础,以便进一步扩展到更复杂的网络应用。