- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
计算机科学与技术学院
实验报告
(2010 -2011学年度 第2学期)
课程名称 分布式系统
实验名称 套接字程序的编程
飞实验目的
熟悉分布式系统中的基于TCP/UDP套接字程序关
于通信的编程的基本原理与方法
二、 实验环境
操作系统:Windows7
开发环境:Eclipse
三、 实验内容
1?月艮务器端:创建套接字;将套接字绑定到一个本 地地址和端口上;将套接字设为监听模式准备接受客 户端请求;等待客户端请求;用返回的套接字和客户端 进行通信;通信完毕,清空套接字。
2?客户端:创建套接字;向服务器端发送连接请求; 和服务器进行通信;关闭套接字
3 ?服务端主要代码说明
getserverO 函数
实例化 Socket 对象: socket 二 server.accept。;
套接字是连接状态:while (true) {
System.outprindn(M等待客户机的连接”); reader 二 new BufferedReadenew InputStreamReader(socket .gctlnputStrcamO)); // 实例化 BuffcrcdRcadcr 对象 gctClicntMcssagcO; // 调用 gctCHcntMcssagcO 方法}
捕捉异常并输出catch (Exception e) {
e.printStackTraccO; }
getclientmessageQ 函 数
套接字是连接状态时:while (true) {
if (readcr.readyO) {
System.out.println(H 客户 机:+ reader, re ad Li neQ);}// 获得客
户端信息
4.客户端主要代门说明
a.连接套接字方法connectO函数
实例化 Socket 对象:socket = new Sockcf 127.0.0.1, 8800);
捕捉异常try {
socket = new Socket(H 127.0.0.1 8998);
writer = new PnntWritcr(sockct.gctOutputStrcarn(), true); ta.append(n完成连接\n”); //文本域中提示信息
a.客户端} catch (Exception c) { c.printStackTraccO; // 输出异常信息 }}
a.客户端
DatagramConncction //建立并打开数据报连接 sender=(DatagramConnection)Connector.open(ndatagram://localhost:5555H);
〃声明要发送的测试数据的长度
int length=l(); //声明要发送数据的数组
byteQ buffer=ne\v bytepength];
for(int i=0;ilcngth;i++) {
buffcr[i]=(byte) (0*+(i% 10));}// 构造 Datagram 对象
Datagram dgram=sender.newDatagram(buffer,buffer.length); //发送数据扌艮 sender, send (d gram); //等待数据报返回
fbr(int i=0;ilength;i++) {
buffer]二(bytc)O;} //接收客户端发回的数据
scndcr.rcccivc(dgram);
lengtli=dgram.getLength();
Systcm.out.println(nreceived return packct^lcngth is+ length); //显示客户 端发
回的数据报中的数据
for(int i=0;ilcngth;i4-+) {
System.out.print(buffer[i]+n );}
b.服务端
Datagram(A)nnection
receiver= (Datagram Connection)Connector.open(Hdatagram:// :5555H);//声明接收数据 的数组
bytc[] buffcr=nc\v byte[256]; //构造 Datagram 对 象
Datagram dgram=receiver.newDatagram(buffer,buffer.length);//等待服务器发
送消息
dgram.setT^ngth(buffer.length); //接 收数据
rcccivcr.rcccivc(dgram);
int lengtli=dgram.getLength();
System.out.println(nDatagram received ?Length i
原创力文档


文档评论(0)