- 浏览: 296848 次
- 性别:
- 来自: 上海
文章分类
最新评论
-
wangweiying123:
import com.sse.monitor.bean.Mes ...
一个项目看java TCP/IP Socket编程(1.3版) -
daxiaoli123:
求源码 448485223@qq.com
一个项目看java TCP/IP Socket编程(1.3版) -
jeromexf:
楼主,求源码,万分感谢(jeromexf@gmail.com) ...
一个项目看java TCP/IP Socket编程(1.3版) -
cuishen:
注意: 网上有人说IE8以下不支持Max-Age, 上面的代码 ...
Response Header Set-Cookie difference in cross browser -
zhunengfei:
刚接触socket,不是太明白,楼主的例子里面工具给的不是很全 ...
一个项目看java TCP/IP Socket编程(1.3版)
前一段时间刚做了个java程序和网络上多台机器的c程序通讯的项目,遵循的是TCP/IP协议,用到了java的Socket编程。网络通讯是java的强项,用TCP/IP协议可以方便的和网络上的其他程序互通消息。
先来介绍下网络协议:
TCP/IP
Transmission Control Protocol 传输控制协议
Internet Protocol 互联网协议
UDP
User Datagram Protocol 用户数据协议
连接协议:
分为:
面向连接协议: Connection Oriented Protocol
非连接协议: Connectionless Protocol
1).面向连接协议是指两台电脑在传输数据前,先会建立一个专属的连接。就如电信局的交换机会为打电话双方提供专属连接一样。
Internet上的面向连接协议就是TCP/IP
特点:确认回应;分组序号;流量控制。
TCP/IP属于可靠性传输,适合不容许有传输错误的网络程序设计使用
2).非连接协议:无专属连接,无分组,容错,距离短,可同时对多台电脑进行数据传输
Internet上的非连接协议就是UDP
TCP在网络通信上有极强的生命力,例如远程连接(Telnet)和文件传输(FTP)都需要不定长度的数据被可靠地传输。相比之下UDP操作简单,而且仅需要较少的监护,因此通常用于局域网高可靠性的分散系统中client/server应用程序。
Socket 是程序与网络间的一种接口,大部分网络应用程序都是点对点的,所谓点就是服务器端和客户端所执行的程序。Socket是用来接收和传送分组的一个端点。
java的Socket编程要用到java.net包,最常用的是net包下的6个类:InetAddress(互联网协议 (IP) 地址)类,Socket(套接字)类,ServerSocket(套接字服务器)类,DatagramSocket(发送和接收数据报包的套接字)类,DatagramPacket(数据报包)类,MulticastSocket(多播数据报套接字类用于发送和接收 IP 多播包)类,其中InetAddress、Socket、ServerSocket类是属于TCP面向连接协议,DatagramSocket、DatagramPacket和MulticastSocket类则属于UDP非连接协议的传送类。
本项目因为使用TCP/IP协议,主要用到Socket和ServerSocket类
项目代码如下
以上是Socket编程,ServerSocket在项目里没有用到,但是我也写了个包装类供参考
Socket编程就是运用Socket或者ServerSocket类搭配线程来使用(由于TCP/IP属于可靠性传输,不会丢包)。可能会因为在发送请求或者接受消息时Socket阻塞而导致主线程挂死,因此发送请求、接收消息的方法要放进子线程里处理;对于同一目标ip和端口,在同一个子线程里只能new一个Socket,也就是说,要对同一地址建立多条连接,就要开启多个线程。而且注意连接可能会因作用不同分长连接和短连接,要分别处理,本项目中发送请求和接受message就分别属于短连接和长连接,因此分别开发了RequestSocketThread和GetMessageSocketThread两个子线程区分对待。可以同时开发个Message类来封装打包和解包消息的方法(项目中开发MessageFactory.java),方便调用
先来介绍下网络协议:
TCP/IP
Transmission Control Protocol 传输控制协议
Internet Protocol 互联网协议
UDP
User Datagram Protocol 用户数据协议
连接协议:
分为:
面向连接协议: Connection Oriented Protocol
非连接协议: Connectionless Protocol
1).面向连接协议是指两台电脑在传输数据前,先会建立一个专属的连接。就如电信局的交换机会为打电话双方提供专属连接一样。
Internet上的面向连接协议就是TCP/IP
特点:确认回应;分组序号;流量控制。
TCP/IP属于可靠性传输,适合不容许有传输错误的网络程序设计使用
2).非连接协议:无专属连接,无分组,容错,距离短,可同时对多台电脑进行数据传输
Internet上的非连接协议就是UDP
TCP在网络通信上有极强的生命力,例如远程连接(Telnet)和文件传输(FTP)都需要不定长度的数据被可靠地传输。相比之下UDP操作简单,而且仅需要较少的监护,因此通常用于局域网高可靠性的分散系统中client/server应用程序。
Socket 是程序与网络间的一种接口,大部分网络应用程序都是点对点的,所谓点就是服务器端和客户端所执行的程序。Socket是用来接收和传送分组的一个端点。
java的Socket编程要用到java.net包,最常用的是net包下的6个类:InetAddress(互联网协议 (IP) 地址)类,Socket(套接字)类,ServerSocket(套接字服务器)类,DatagramSocket(发送和接收数据报包的套接字)类,DatagramPacket(数据报包)类,MulticastSocket(多播数据报套接字类用于发送和接收 IP 多播包)类,其中InetAddress、Socket、ServerSocket类是属于TCP面向连接协议,DatagramSocket、DatagramPacket和MulticastSocket类则属于UDP非连接协议的传送类。
本项目因为使用TCP/IP协议,主要用到Socket和ServerSocket类
项目代码如下
package com.sse.monitor.serv; import java.io.DataInputStream; import java.io.IOException; import java.io.InputStream; import java.io.OutputStream; import java.io.BufferedOutputStream; import java.net.Socket; import java.net.UnknownHostException; import java.util.ArrayList; import com.sse.monitor.bean.Message; import com.sse.monitor.bean.MessageHead; import com.sse.monitor.bean.ResponseMessage; import com.sse.monitor.form.ListenerInvoke; import com.sse.monitor.form.MainForm; import com.sse.monitor.util.SwingUtils; /** * Socket套接字工厂,对外接口是静态方法 SocketFactory.request(String, String, String, int) * Copyright: Copyright (c) 2008 * Company: conserv * @author cuishen * @version 1.3 */ public class SocketFactory { private Socket socket = null; private String targetIpAddress = null; private int targetPort = 0; private static SocketFactory sf = new SocketFactory(); public SocketFactory() { } /** * 建立一条TCP/IP连接 * @param targetIpAddress String 目标ip地址 * @param targetPort String 目标端口 * @throws IOException */ private void connect(String targetIpAddress, int targetPort) throws IOException { setTargetIpAddress(targetIpAddress); setTargetPort(targetPort); if(socket == null) socket = new Socket(targetIpAddress, targetPort); } /** * 这是对外接口。发送命令,接收反馈和接收message放两个线程, * 发送命令并接收反馈是短连接,所以每次执行成功后,将销毁socket并终止线程, * 接收message是长连接,所以可能会new出n个线程,建议对接收message的线程做缓存 * @param commandType String 命令类型 * @param commandContent String 命令内容 * @param targetIP String 目标ip * @param targetPort int 目标端口 */ public static void request(String commandType, String commandContent, String targetIP, int targetPort) { if (commandType.equalsIgnoreCase(MessageFactory.SCAN_COMMAND)) { sf.new GetMessageSocketThread(commandType, commandContent, targetIP, targetPort); } else { sf.new RequestSocketThread(commandType, commandContent, targetIP, targetPort); } } /** * 发送请求 * @param commandType String 命令类型 * @param commandContent String 命令内容 * @param targetIp String 目标ip */ private void sendRequest(String commandType, String commandContent, String targetIp) { OutputStream os = null; BufferedOutputStream bs = null; try { os = socket.getOutputStream(); bs = new BufferedOutputStream(os); char[] message = MessageFactory.makeRequestMessage(targetIp, commandType, commandContent, MessageFactory.COMMAND_TRADE_CODE, MessageFactory.RIGHT_COMMAND, MessageFactory.MESSAGE_END_FLAG); for (int i = 0; i < message.length; i++) bs.write(new String(message).getBytes(), i, 1); bs.flush(); SwingUtils.appendLog(MainForm.jTextArea, "发送请求:'" + commandType + "' '" + commandContent + "' '" + targetIp + "'", ReadConfig.commandStateShowLineCount); } catch (IOException e) { SwingUtils.appendLog(MainForm.jTextArea, "Error!!! 发送请求:'" + commandType + "' '" + commandContent + "' '" + targetIp + "'失败!! " + e.getMessage(), ReadConfig.commandStateShowLineCount); e.printStackTrace(); } catch (Exception e) { e.printStackTrace(); } finally { } } /** * 获得反馈 * * @return 如果成功获得反馈,则返回true;否则返回false */ private boolean getResponse() { InputStream is = null; DataInputStream di = null; boolean returnFlag = false; try { is = socket.getInputStream(); di = new DataInputStream(is); byte[] temp = new byte[1]; int flag = 0; ArrayList tempByteList = new ArrayList(); int i = 0; while (flag != -1) { i++; flag = di.read(temp = new byte[1]); if (flag != -1) tempByteList.add(temp); if (i == 38) break; } if (i == 1) { SwingUtils.Error("未收到response!!!"); return false; } MessageHead messageHead = MessageFactory.readHead(tempByteList); SwingUtils.appendLog(MainForm.jTextArea, "收到 response", ReadConfig.commandStateShowLineCount); tempByteList = new ArrayList(); i = 0; while (flag != -1) { i++; flag = di.read(temp = new byte[1]); if (flag != -1) tempByteList.add(temp); if (i == 26) break; } byte[] length = new byte[4]; di.read(length); int len = Integer.parseInt(new String(length, MessageFactory.DEFAULT_CHAR_SET).trim()); flag = 0; for (int j = 0; j < (len + 37); j++) { flag = di.read(temp = new byte[1]); if (flag == -1) break; tempByteList.add(temp); } ResponseMessage rm = MessageFactory.readResponseMessage(tempByteList, len); if (messageHead.getErrorCode().equals(MessageFactory.SUCCESS)) returnFlag = true; else SwingUtils.Error("errorCode: " + messageHead.getErrorCode() + "; content: " + rm.getCommandContent()); } catch (IOException e) { e.printStackTrace(); } finally { } return returnFlag; } /** * 分发消息的方法,将消息按进程名发送到对应的消息缓存 * * 消息缓存ListenerInvoke.messageMap,key = machineName + * '|' + programName + '|' + processId, value = messageList * 存放messageMap里面的键名的List -- ListenerInvoke.messageMapKeyList * 进程状态缓存ListenerInvoke.processStateMap, key = machineName + '|' + * programName + '|' + processId, value = String * * @param message Message */ private void distributeMess(Message message) { String machineName = message.getMachineName(); String programName = message.getProgramName(); String processId = message.getProcessId(); String content = message.getContent(); String key = machineName + '|' + programName + '|' + processId; key = key.trim(); ArrayList messageList = null; if (ListenerInvoke.messageMap.get(key) == null) { synchronized (ListenerInvoke.messageMap) { if (ListenerInvoke.messageMap.get(key) == null) { messageList = new ArrayList(); messageList.add(content); ListenerInvoke.messageMap.put(key, messageList); } } } else { messageList = (ArrayList) ListenerInvoke.messageMap.get(key); synchronized (messageList) { if (ListenerInvoke.messageMap.get(key) != null) { messageList.add(content); if (!ReadConfig.threadDeleteMessCacheOrFIFO && messageList.size() >= ReadConfig.messageCacheSizeLimit) messageList.remove(0); } } } if (!ListenerInvoke.messageMapKeyList.contains(key)) { synchronized (ListenerInvoke.messageMapKeyList) { if (!ListenerInvoke.messageMapKeyList.contains(key)) ListenerInvoke.messageMapKeyList.add(key); } } } /** * 接收message * @return Message */ private boolean getMessage() { InputStream is = null; DataInputStream di = null; Message message = null; try { if (this.socket == null) return false; is = this.socket.getInputStream(); if (is == null) return false; di = new DataInputStream(is); byte[] temp = new byte[1]; int flag = 0; ArrayList tempByteList = new ArrayList(); int i = 0; while (flag != -1) { i++; flag = di.read(temp = new byte[1]); if (flag != -1) tempByteList.add(temp); if (i == 38) break; } if (i == 1) return false; tempByteList = new ArrayList(); i = 0; while (flag != -1) { i++; flag = di.read(temp = new byte[1]); if (flag != -1) tempByteList.add(temp); if (i == 74) break; } byte[] length = new byte[4]; di.read(length); int len = Integer.parseInt(new String(length, MessageFactory.DEFAULT_CHAR_SET).trim()); flag = 0; for (int j = 0; j < len; j++) { flag = di.read(temp = new byte[1]); if (flag == -1) break; tempByteList.add(temp); } message = MessageFactory.readMessage(tempByteList, len); SwingUtils.appendLog(MainForm.jTextArea, "收到新 Message", ReadConfig.commandStateShowLineCount); distributeMess(message);// 分发message } catch (IOException e) { e.printStackTrace(); } finally { } return true; } /** * 负责发送请求接收反馈的内部线程类,每new一个RequestSocketThread线程, * 就new一个socket,建立一条专属连接,成功接收反馈后将销毁socket,终止线程。 * 将发送请求,接收反馈放进内部线程处理,是为了防止套接字阻塞造成主线程挂死。 * @author cuishen * @version 1.2 */ class RequestSocketThread implements Runnable { private SocketFactory socketFactory; private String commandType = null; private String commandContent = null; private String targetIP = null; Thread t; public RequestSocketThread(String commandType, String commandContent, String targetIP, int targetPort) { this.socketFactory = new SocketFactory(); try { this.socketFactory.connect(ReadConfig.targetIpAddress, ReadConfig.targetPort); } catch (UnknownHostException e) { SwingUtils.Error("主机 IP 地址无法确定,无法建立连接! targetIP=" + ReadConfig.targetIpAddress + ", targetPort=" + ReadConfig.targetPort); e.printStackTrace(); } catch (IOException e) { SwingUtils.Error("访问被拒绝,无法建立连接,请检查网络! targetIP=" + ReadConfig.targetIpAddress + ", targetPort=" + ReadConfig.targetPort); e.printStackTrace(); } this.commandType = commandType; this.commandContent = commandContent; this.targetIP = targetIP; t = new Thread(this); t.start(); } public void run() { this.socketFactory.sendRequest(commandType, commandContent, targetIP); this.socketFactory.getResponse(); stopThread(); } public void stopThread() { try { this.commandType = null; this.commandContent = null; this.targetIP = null; socketFactory.closeSocket(); socketFactory = null; this.t.join(100); } catch (InterruptedException e) { e.printStackTrace(); } finally { t = null; } } } /** * 负责接收message的内部线程类,每new一个GetMessageSocketThread线程, * 就new一个socket,建立一条专属TCP/IP连接,getMessage是长连接,所以建议 * 将该线程放入缓存方便管理 * @author cuishen * @version 1.2 */ class GetMessageSocketThread implements Runnable { private SocketFactory socketFactory; private String commandType = null; private String commandContent = null; private String targetIP = null; Thread t; private boolean flag = false; private boolean ifGetResponse = true; private boolean ifGetMessage = true; private boolean ifSendRequest = true; private boolean ifCycle = true; public GetMessageSocketThread(String commandType, String commandContent, String targetIP, int targetPort) { this.socketFactory = new SocketFactory(); try { this.socketFactory.connect(ReadConfig.targetIpAddress, ReadConfig.targetPort); } catch (UnknownHostException e) { SwingUtils.Error("主机 IP 地址无法确定,无法建立连接! targetIP=" + ReadConfig.targetIpAddress + ", targetPort=" + ReadConfig.targetPort); e.printStackTrace(); } catch (IOException e) { SwingUtils.Error("访问被拒绝,无法建立连接,请检查网络! targetIP=" + ReadConfig.targetIpAddress + ", targetPort=" + ReadConfig.targetPort); e.printStackTrace(); } this.commandType = commandType; this.commandContent = commandContent; this.targetIP = targetIP; t = new Thread(this); t.start(); } public void run() { while (ifCycle) { if (ifSendRequest) { this.socketFactory.sendRequest(commandType, commandContent, targetIP); ifSendRequest = false; } if (ifGetResponse) { flag = socketFactory.getResponse(); ifGetResponse = false; } if (flag && ifGetMessage && socketFactory.socket != null) { if (!socketFactory.getMessage()) { try { Thread.sleep(ReadConfig.getMessageThreadSleep); } catch (InterruptedException e) { e.printStackTrace(); } } } } } public void stopThread() { try { this.commandType = null; this.commandContent = null; this.targetIP = null; ifGetMessage = false; ifCycle = false; socketFactory.closeSocket(); socketFactory = null; this.t.join(100); } catch (InterruptedException e) { e.printStackTrace(); } finally { t = null; } } } /** * 关闭套接字 */ private void closeSocket() { try { if (!socket.isClosed()) socket.close(); socket = null; } catch (IOException e) { e.printStackTrace(); } } /** * @return the targetIpAddress */ public String getTargetIpAddress() { return targetIpAddress; } /** * @param targetIpAddress * the targetIpAddress to set */ public void setTargetIpAddress(String targetIpAddress) { this.targetIpAddress = targetIpAddress; } /** * @return the targetPort */ public int getTargetPort() { return targetPort; } /** * @param targetPort * the targetPort to set */ public void setTargetPort(int targetPort) { this.targetPort = targetPort; } }
以上是Socket编程,ServerSocket在项目里没有用到,但是我也写了个包装类供参考
package com.sse.monitor.serv; import java.io.IOException; import java.net.ServerSocket; import java.net.Socket; /** * 服务器套接字工厂 * Copyright: Copyright (c) 2008 * @author cuishen * @version 1.0 */ public class ServerSocketFactory { private static ServerSocket server; private static Socket client; private boolean ifRunServer = true; public void runServer(int port) throws IOException { //本地建立一个套接字服务器,等待其他机器访问 server = new ServerSocket(port); System.out.println("Socket Server Start..."); new ServerThread(); } class ServerThread implements Runnable { Thread t; public ServerThread() { t = new Thread(this); t.start(); } public void run() { try { while(ifRunServer) { if(client == null) client = server.accept(); if(client != null) //getMessage(); Thread.sleep(ReadConfig.serverThreadSleep); } } catch (InterruptedException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } } public void stopThread() { try { ifRunServer = false; this.t.join(100); } catch (InterruptedException ex) { System.out.println("socket服务器线程终止异常!!!"); } finally { t = null; } } } }
Socket编程就是运用Socket或者ServerSocket类搭配线程来使用(由于TCP/IP属于可靠性传输,不会丢包)。可能会因为在发送请求或者接受消息时Socket阻塞而导致主线程挂死,因此发送请求、接收消息的方法要放进子线程里处理;对于同一目标ip和端口,在同一个子线程里只能new一个Socket,也就是说,要对同一地址建立多条连接,就要开启多个线程。而且注意连接可能会因作用不同分长连接和短连接,要分别处理,本项目中发送请求和接受message就分别属于短连接和长连接,因此分别开发了RequestSocketThread和GetMessageSocketThread两个子线程区分对待。可以同时开发个Message类来封装打包和解包消息的方法(项目中开发MessageFactory.java),方便调用
评论
13 楼
wangweiying123
2016-09-29
import com.sse.monitor.bean.Message;
import com.sse.monitor.bean.MessageHead;
import com.sse.monitor.bean.ResponseMessage;
import com.sse.monitor.form.ListenerInvoke;
这几个代码能否发来看看 谢谢 邮箱wangweiying315@163.com
import com.sse.monitor.bean.MessageHead;
import com.sse.monitor.bean.ResponseMessage;
import com.sse.monitor.form.ListenerInvoke;
这几个代码能否发来看看 谢谢 邮箱wangweiying315@163.com
12 楼
daxiaoli123
2015-04-15
求源码 448485223@qq.com
11 楼
jeromexf
2014-08-28
楼主,求源码,万分感谢(jeromexf@gmail.com)
10 楼
zhunengfei
2014-06-27
刚接触socket,不是太明白,楼主的例子里面工具给的不是很全,让我看不到效果,很抽象
9 楼
zhunengfei
2014-06-27
求源码,谢谢师兄,写的不错 ;zhunengfei@gmail.com
8 楼
lj1096959784
2014-04-27
楼主,求源码,万分感谢(1096959784@qq.com)
7 楼
Arthuroo
2014-03-03
真心求源码
6 楼
Arthuroo
2014-03-03
求楼主源码啊,找了很多天了都没找到,邮箱:414038013@qq.com
5 楼
happycredit
2009-03-08
那你客户端的C程序通信是什么样子的呢?如何实现的呢?谢谢
我现在的毕业设计也是采用这种架构,即客户端AVR单片机发送AT命令控制GPRS模块,服务器端监控软件放在互联网上,现在就是搞不清客户端的处理逻辑
请尽快回答,谢拉阿
我现在的毕业设计也是采用这种架构,即客户端AVR单片机发送AT命令控制GPRS模块,服务器端监控软件放在互联网上,现在就是搞不清客户端的处理逻辑
请尽快回答,谢拉阿
4 楼
happycredit
2009-03-08
那你客户端的C程序通信是什么样子的呢?如何实现的呢?谢谢
我现在的毕业设计也是采用这种架构,即客户端AVR单片机发送AT命令控制GPRS模块,服务器端监控软件放在互联网上,现在就是搞不清客户端的处理逻辑
我现在的毕业设计也是采用这种架构,即客户端AVR单片机发送AT命令控制GPRS模块,服务器端监控软件放在互联网上,现在就是搞不清客户端的处理逻辑
3 楼
raymond323
2009-02-25
import com.sse.monitor.bean.Message;
import com.sse.monitor.bean.MessageHead;
import com.sse.monitor.bean.ResponseMessage;
import com.sse.monitor.form.ListenerInvoke;
这几个代码能否发来看看 谢谢诶
import com.sse.monitor.bean.MessageHead;
import com.sse.monitor.bean.ResponseMessage;
import com.sse.monitor.form.ListenerInvoke;
这几个代码能否发来看看 谢谢诶
2 楼
cuishen
2009-01-23
SocketFactory 的项目代码已经更新到1.3版,对distributeMess()方法(分发消息缓存)的线程同步问题做了优化,使线程更安全
1 楼
jelver
2008-12-04
不错,期待楼主再接再厉
发表评论
-
设计模式---观察者模式(Observer Pattern with java)
2013-08-22 12:26 1734java中的 Listener - Event 是应用了设计模 ... -
java单线程实现队列模型
2013-04-23 17:51 8925以下是我整理的用java单线程实现队列Queue的代码模型。 ... -
Java线程安全隐患
2012-02-10 15:16 1801最近一直在考虑java线程 ... -
java代码调优笔记(一)
2011-10-28 13:30 1528(1). 用Boolean.valueOf(boolean ... -
浅析java callback 回调模式
2009-08-03 11:36 12531看过spring、hibernate源码的朋友对callbac ... -
基于javassist实现对接口的动态代理引擎
2009-07-07 23:51 8524一提到jdk中的java.lang.reflect.Proxy ... -
java程序性能优化之找出内存溢出元凶
2009-06-08 08:47 7465我曾经在刚入行的时候 ... -
Log4J使用完全手册(转)
2007-11-20 15:04 5252Log4J是Apache的一个开放 ... -
神奇的java反射机制
2007-07-28 22:44 4215最近在开发一个小型的j2ee项目,沿用以前公司成熟的strut ... -
解决dom4j无法解析xml命名空间的问题
2006-11-26 19:29 5979困扰我几周的dom4j无法 ... -
dom4j中处理XML命名空间的问题,哪位指点下,谢谢!!!
2006-11-23 21:57 2681要用dom4j解析的带命名空间的xml文档如下: ---my ... -
关于dom4j无法读取xml文件的问题,已经困扰我几个礼拜了,哪位指点迷津!
2006-11-21 20:22 3238要读取的xml文件1----myXML.xml,放在c盘根目录 ...
相关推荐
Java TCP/IP Socket编程是Java网络通信的核心技术,广泛应用于服务器端和客户端之间的数据传输。这本书的第二版深入探讨了如何使用Java实现TCP/IP协议栈的socket接口,为开发者提供了全面的理论知识和实践指导。 ...
《Java TCP/IP Socket编程(原书第2版)》基于TCP/IP Socket相关原理,对如何在Java中进行Socket编程作了深入浅出的介绍。《Java TCP/IP Socket编程(原书第2版)》内容简明扼要,条理清晰,并在讲解相应的概念或编程...
Java TCP/IP Socket编程是Java网络编程中的重要组成部分,它提供了在网络间进行数据传输的基础机制。TCP(Transmission Control Protocol)和IP(Internet Protocol)是互联网上最基础的通信协议,而Socket则是TCP/...
总的来说,《Java + TCP/IP + Socket编程++ 原书第2版》可能会涵盖这些主题:TCP/IP协议基础,Java Socket API的使用,异常处理,多线程编程,以及网络编程的最佳实践。这本书将帮助开发者深入理解如何在Java环境中...
Java TCP/IP Socket编程原书第2版.pdf 个人收集电子书,仅用学习使用,不可用于商业用途,如有版权问题,请联系删除!
本书的新版涵盖了Java的当前最新版本的内容(7.5版至1.7版),以及一些新的重要的抽象,包括NetworkInterface,InterfaceAddress,Inet4/6Address抽象、SocketAddress InetSocketAddressf1]Executor等。现在几乎...
本资源包含一本关于Java TCP/IP Socket编程的书籍及其配套源代码,对于深入理解Socket编程至关重要。 书籍《Java TCP/IP Socket编程原书第2版》详细阐述了如何在Java环境中利用Socket进行网络通信。书中涵盖的知识...
Java TCP/IP Socket编程是网络通信领域中的核心技术,尤其在Java编程中,Socket是实现客户端与服务器之间通信的基础。本资料“Java TCP-IP Socket编程-卡尔弗特.pdf”旨在深入探讨如何利用Java语言进行TCP/IP套接字...
在7CP/IP Socket首次发布时,Java作为一个新的未被关注的编程语 言刚出现。然而,自2001年以来,Java的网络编程能力已经得到了很大程度的扩展,而且 持续的应用优势已经使其成为了一个占主导地位的平台。考虑到Java...
Java TCP/IP Socket编程是网络通信领域中的核心技术,尤其在Java平台中,Socket是实现客户端与服务器之间通信的基础。原书第二版深入浅出地讲解了Java Socket编程的各个方面,为开发者提供了全面的学习资源。以下是...
《Java TCP IP Socket编程(原书第2版)》
两本TCP/IP socket编程书,分别是C语言和Java语言版的。都是文字版的pdf文档。 1. TCP/IP Sockets in Java (2th Edtion) 2. TCP/IP Sockets in C *Series Editor: Michael J. Donahoo
Java TCP_IP Socket编程(原书第2版).mobi、java底层协议通讯
Java实现的Socket编程是基于TCP/IP协议的,它提供了一个可靠的数据流服务,可以实现客户端和服务器之间的数据交换。Java中的Socket类和ServerSocket类是两种基本的套接字类,Socket类用于建立客户端和服务器之间的...
《Java TCP/IP Socket编程》(原书第2版)是一本深入探讨Java中Socket编程的专著,旨在帮助读者理解并掌握如何在Java环境中利用TCP/IP协议进行网络通信。本书不仅详细介绍了Socket的工作原理,还提供了丰富的示例...
在计算机网络领域,TCP/IP是一组用于互联网数据传输的协议,而Socket编程则是实现这些协议功能...通过上述知识点的介绍,可以了解Java TCP/IP Socket编程的基础和进阶内容,以及如何利用Java语言开发高性能的网络应用。
根据提供的文件信息,...以上知识点构成了对《TCP/IP Sockets in Java, 2nd Edition.pdf》文件的详细解析,涵盖了TCP/IP和Socket编程的基础知识,Java实现网络通信的方法,以及网络编程在实际中的应用实例和高级主题。
Java TCP/IP Socket编程是网络通信领域中的核心技术,它允许两台计算机通过Internet进行双向通信。在这个自制品中,我们看到的是一个基于Java实现的简单聊天工具,它利用Socket API构建了一个用户界面,使得用户可以...