第十章-网络编程.doc

  1. 1、本文档共18页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第十章 JAVA分布式计算技术之网络编程 基本概念 什么是计算机网络 把分布在不同地理区域的计算机与专门的外部设备用通信线路互连成一个规模大、功能强的网络系统,从而使众多的计算机可以方便地互相传递信息,共享硬件、软件、数据信息等资源 计算机网络的主要功能 资源共享 信息传输与集中处理 均衡负荷与分布处理 综合信息服务 (www/综合业务数字网络 ISDN) 什么是网络通信协议 计算机网络中实现通信必须有一些约定即通信协议,对速率、传输代码、代码结构、传 输控制步骤、出错控制等制定标准。 网络通信接口 为了使两个结点之间能进行对话,必须在它们之间建立通信工具(即接口),使彼此之间 能进行信息交换。接口包括两部分: 硬件装置: 实现结点之间的信息传送 软件装置: 规定双方进行通信的约定协议 为什么要分层 由于结点之间联系很复杂,在制定协议时,把复杂成份分解成 一些简单的成份,再将它们复合起来。最常用的复合方式是层次方式,即同层间可以通信、上一层可以调用下一层,而与再下一层不发生关系。 通信协议的分层规定 把用户应用程序作为最高层,把物理通信线路作为最低层,将其间的协议处理分为若干层,规定每层处理的任务,也规定每层的接口标准。 1、物理层(Physical Layer) 2、数据链路层(Data Link Layer) 3、网络层(Network Layer)网络层协议的代表包括:IP、IPX、RIP、OSPF等 4、传输层(Transport Layer)传输层协议的代表包括:TCP、UDP、SPX等。 5、会话层(Session Layer)NetBIOS、ZIP(AppleTalk区域信息协议)等。 6、表示层(Presentation Layer) ASCII、ASN.1、JPEG、MPEG等。 7、应用层(Application Layer) Telnet、FTP、HTTP、SNMP等。 数据封装 数据拆封: TCP和UDP 在网络通讯中,TCP方式就类似于拨打电话,使用该种方式进行网络通讯时,需要建立专门的虚拟连接,然后进行可靠的数据传输,如果数据发送失败,则客户端会自动重发该数据。而UDP方式就类似于发送短信,使用这种方式进行网络通讯时,不需要建立专门的虚拟连接,传输也不是很可靠,如果发送失败则客户端无法获得。 这两种传输方式都是实际的网络编程中进行使用,重要的数据一般使用TCP方式进行数据传输,而大量的非核心数据则都通过UDP方式进行传递,在一些程序中甚至结合使用这两种方式进行数据的传递。 由于TCP需要建立专用的虚拟连接以及确认传输是否正确,所以使用TCP方式的速度稍微慢一些,而且传输时产生的数据量要比UDP稍微大一些。 TCP(transfer control protocol)是面向连接的,所谓面向连接,就是当计算机双方通信时必需先建立连接,然后数据传送,最后拆除连接三个过程 并且TCP在建立连接时又分三步走: 第一步是请求端(客户端)发送一个包含SYN即同步(Synchronize)标志的TCP报文,SYN同步报文会指明客户端使用的端口以及TCP连接的初始序号; 第二步,服务器在收到客户端的SYN报文后,将返回一个SYN+ACK的报文,表示客户端的请求被接受,同时TCP序号被加一,ACK即确认(Acknowledgement)。 第三步,客户端也返回一个确认报文ACK给服务器端,同样TCP序列号被加一,到此一个TCP连接完成。然后才开始通信的第二步:数据处理。 这就是所说的TCP三次握手(Three-way Handshake)。 Syn Flood洪水攻击。。。 IP: IPV4, IPV6(未来!), IPV9(未来未来!) 端口: QQ, msn, 迅雷/电驴/360. 通过端口,可以在一个主机上运行多个网络应用程序。端口是虚拟的概念,并不是说在主机上真的有若干个端口。 Java为了可移植性,不允许直接调用操作系统,而是由包来提供网络功能。Java虚拟机负责提供与操作系统的实际连接。J中包含如下重要的类: InetAddress: 封装计算机的ip地址和DNS. 这个类没有构造函数。如果要得到对象,只能通过静态方法:getLocalHost, getByName, getAllByName, getAddress, getHostName 只有IP和主机名,没有端口: //使用getLocalHost方法创建InetAddress对象 // InetAddress addr = InetAddress.getLocalHost(); // System.out.println(addr.getHos

文档评论(0)

zzqky + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档