




已阅读5页,还剩39页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
Java编程思想 第十五章 分布式计算 网络编程简介 socket 同一个网络上的机器间信息交换网络编程是基于IP协议的网络编程通过streams和sockets来实现 识别一台机器 DNS DomainNameSystem 名称 等等IP地址 123 255 28 120InetAddressInetAddress getByName String DeterminestheIPaddressofahost or206 26 48 100 c15 WhoAmI java p653 Findsoutyournetworkaddresswhen you reconnectedtotheI publicclassWhoAmI publicstaticvoidmain String args throwsException if args length 1 System err println Usage WhoAmIMachineName System exit 1 InetAddressa InetAddress getByName args 0 System out println a Ans C JavaWhoImIlocalhostLocalhost 127 0 01C JavaWhoImItjuTju 127 0 0 1 IP地址分配 静态IP和动态IP静态IP是一个固定的地址 它必须是唯一的一个动态IP是由在同一个网络中的DHCP DynamicHostConfigurationProtocol 服务器来分配的 IP地址分配 Internet DHCP服务器 静态IP 动态IP 服务器和客户机 服务器 提供服务 比如Web服务器 FTP服务器客户机 连接服务器来请求信息 服务器和客户机 Internet Web服务器Ftp服务器 服务器 客户机 端口1 端口2 Sockets 端口 port 一个IP地址并不足以完整标识一个服务器一台物理性的机器中 往往运行着多个服务器 程序 端口定义一台机器上的一种服务 软件抽象概念 系统分配总数1 1024你可以定义自己的端口从1025开始 Sockets 一个服务器与客户机之间连线的终端针对一个特定的连接 每台机器上都有一个 套接字 可以想象它们之间有一条虚拟的 线缆 一个socket可以被认为是一个本地文件你可以通过streams读 写一个socket ServerSocket 服务器使用一个ServerSocket对象来侦听一个连接的端口ServerSocket accept 一旦一个客户建立了一个连接 将返回一个socketaccept 方法会暂时陷入停顿状态 阻塞 直到某个客户尝试同它建立连接 但其他进程仍能正常运行 简单的服务器和客户端 服务器 p656 客户端 p658 c15 JabberServer java服务器 先运行 p656 Verysimpleserverthatjust echoeswhatevertheclientsends importjava io publicclassJabberServer Chooseaportoutsideoftherange1 1024 publicstaticfinalintPORT 8080 publicstaticvoidmain String args throwsIOException ServerSockets newServerSocket PORT System out println Started s 等待客户端连上 try Blocksuntilaconnectionoccurs Socketsocket s accept try System out println Connectionaccepted socket BufferedReaderin newBufferedReader newInputStreamReader socket getInputStream OutputisautomaticallyflushedbyPrintWriter PrintWriterout newPrintWriter newBufferedWriter newOutputStreamWriter socket getOutputStream true while true Stringstr in readLine 从客户端读取信息if str equals END break System out println Echoing str 在屏幕上输出读取信息out println str 输出到客户端 Alwaysclosethetwosockets finally System out println closing socket close finally s close c15 JabberClient java客户端 后运行 p658 Verysimpleclientthatjustsends linestotheserverandreadslines importjava io publicclassJabberClient publicstaticvoidmain String args throwsIOException PassingnulltogetByName producesthe special LocalLoopback IPaddress for testingononemachinew oanetwork InetAddressaddr InetAddress getByName null Alternatively youcanuse theaddressorname InetAddressaddr InetAddress getByName 127 0 0 1 InetAddressaddr InetAddress getByName localhost System out println addr addr Socketsocket newSocket addr 8080 JabberServer PORT Guardeverythinginatry finallytomake surethatthesocketisclosed try System out println socket socket BufferedReaderin newBufferedReader newInputStreamReader socket getInputStream OutputisautomaticallyflushedbyPrintWriter PrintWriterout newPrintWriter newBufferedWriter newOutputStreamWriter socket getOutputStream true for inti 0 i 10 i out println howdy i 输出到服务器Stringstr in readLine 从服务器读回信息System out println str 在屏幕上输出读回信息 out println END finally System out println closing socket close Ans Clientaddr localhost 127 0 0 1socket Socket addr localhost 127 0 0 1 port 8080 localport 1036 howdy0howdy1howdy2howdy3howdy4howdy5howdy6howdy7howdy8howdy9closing Ans ServerStarted ServerSocket addr 0 0 0 0 0 0 0 0 port 0 localport 8080 Connectionaccepted Socket addr 127 0 0 1 port 1036 localport 8080 Echoing howdy0Echoing howdy1Echoing howdy2Echoing howdy3Echoing howdy4Echoing howdy5Echoing howdy6Echoing howdy7Echoing howdy8Echoing howdy9closing TCPvs Datagrams 消息通过包来传送TCP TransferControlProtocol 有保证的传递 慢UDP UserDatagramProtocol 不可靠 快 Datagrams UDP 类DatagramSocket用来支持数据报通讯 DatagramSocket DatagramSocket intport 类DatagramPackte传输数据的载体 DatagramPackte bytebuf intlength DatagramPackte bytebuf intlength InetAddressaddr intport voidreceive DatagramPacketp voidsend DatagramPacketp 使用UDP编程客户端importjava io importjava util classQuoteClient publicstaticvoidmain String args intport InetAddressaddress DatagramSocketsocket null DatagramPacketpacket byte sendBuff newbyte 256 if args length 2 System out println Usage javaQuoteClient return try socket newDatagramSocket bindtothesocket catch SocketExceptione System err println Couldnotcreatedatagramsocket if socket null try sendrequestport Integer parseInt args 1 address InetAddress getByName args 0 packet newDatagramPacket sendBuff 256 address port socket send packet getresponsepacket newDatagramPacket sendBuff 256 socket receive packet Stringreceived newString packet getData 0 System out println QuoteoftheMoment received socket close catch IOExceptione System err println IOException e e printStackTrace 使用UDP编程服务器端importjava io importjava util classQuoteServerThreadextendsThread privateDatagramSocketsocket null privateDataInputStreamqfs null QuoteServerThread super QuoteServer try socket newDatagramSocket System out println QuoteServerlisteningonport socket getLocalPort catch SocketExceptione System err println Couldnotcreatedatagramsocket this openInputFile publicvoidrun if socket null return while true try byte buf newbyte 256 DatagramPacketpacket InetAddressaddress intport StringdString null receicerequestpacket newDatagramPacket buf 256 socket receive packet address packet getAddress port packet getPort sendresponseif qfs null dString newDate toString elsedString getNextQuote dString getBytes 0 dString length buf 0 packet newDatagramPacket buf buf length address port socket send packet catch IOExceptione System err println IOException e e printStackTrace protectedvoidfinalize if socket null socket close socket null System out println Closingdatagramsocket privatevoidopenInputFile try qfs newDataInputStream newFileInputStream one liners txt catch java io FileNotFoundExceptione System out println Couldnotopenquotefile Servingtimeinstead privateStringgetNextQuote StringreturnValue null try if returnValue qfs readLine null qfs close this openInputFile returnValue qfs readLine thefilehasatleastoneinputline catch IOExceptione returnValue IOExceptionoccurredinserver returnreturnValue classQuoteServer publicstaticvoidmain String args newQuoteServerThread start URL UniformResouseLocator URL 统一资源位置例如 JNLP JavaNetworkLaunchProtocol 简介 签名appletsJava网络加载协议 JNLP 和JavaWebStart JAWS 签名applets Sandbox模型 applet访问本地磁盘和连接本地网络被拒绝一个已签名的applet将允许用户验证其合法性证书 将一个applet进行签名 需要将这个applet封装在一个jar文件中并将jar文件用一个证书或者密钥进行标记 签名applets 证书 证书 由一个可信实体颁发 例如VeriSign Thawte用于检验目的 你可以创建自己的证书 keytool genkey alia
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 七年级英语上册 Unit 3 Is this your pencil第3课时教学设计(新版)人教新目标版
- 防灾减灾日地震安全培训
- 三年级上美术教学设计-天外来客-苏少版
- 对客服务用语规范性培训
- 二年级语文下册 第六单元 17 要是你在野外迷了路教学设计 新人教版
- 2024中国铝业集团有限公司华东区域法律中心法律顾问招聘1人笔试参考题库附带答案详解
- 人教部编版六年级下册第二单元单元综合与测试表格教案及反思
- 九年级化学下册 第8单元 金属和金属材料 实验活动4 金属的物理性质和某些化学性质教学设计 (新版)新人教版
- 九年级道德与法治上册 第3单元 推进政治文明 第6课 建设法治中国 第2框 弘扬法治精神教学设计 北师大版
- 七年级地理下册 第七章 第三节 印度教学设计 新人教版
- 汉字的五行属性与三才五格计算方法
- 唐山高科总部大厦幕墙工程幕墙招标技术评估总结
- 苏教版三年级下册数学 第三单元 解决问题的策略 测试卷
- 生产作业流程图
- 10kV线路拆除
- 高中学生选课指导手册
- 为老年人更换纸尿裤评分标准
- 教务管理系统UML模型PPT课件
- 吸收塔及烟囱施工方案
- 高中数学答题卡模板word版(共2页)
- 小型构件预制场建设方案
评论
0/150
提交评论