- 1、本文档共3页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
实验四、web效劳器套接字编程
1.实验目的:
编写一个WEB效劳器程序,可以接受来自浏览器的访问,并传输页面(包含多个对象)到浏览器。掌握Socket编程。
2.实验环境:
连入局域网络的主机一台。
3.实验指导:
超文本传输协议〔〕是位于TCP/IP协议的应用层,是最广为人知的协议,也是互连网中最核心的协议之一。协议是Web浏览器和Web效劳器之间的应用层协议,是通用的、无状态的、面向对象的协议。
一个完整的协议会话过程包括四个步骤:
连接
Web浏览器与Web效劳器建立连接,翻开一个称为Socket〔套接字〕的虚拟文件,此文件的建立标志着连接建立成功;
请求
Web浏览器通过Socket向Web效劳器提交请求。的请求一般是GET或POST命令〔POST用于FORM参数的传递〕;
应答
Web浏览器提交请求后,通过协议传送给Web效劳器。Web效劳器接到后,进行事务处理,处理结果又通过传回给Web浏览器,从而在Web浏览器上显示出所请求的页面;
关闭连接
应答结束后Web浏览器与Web效劳器必须断开,以保证其它Web浏览器能够与Web效劳器建立连接。
4.实验分析,答复以下问题。
运行实验提供的Webserver.java程序,分析该程序实现的功能。
提示:使用WEB浏览器来测试WEB效劳器的程序,如果在本机上测试,本机效劳器监听端口为6789,要获得本机上文件名为index.html,应在浏览器指定以下URL://localhost:6789/index.html;如果效劳器程序不在本机上,效劳器监听端口为6789,要获得效劳器上文件名为index.html,应在浏览器指定以下URL://效劳器IP地址:6789/index.html
//websever程序
importjava.io.*;
importjava.net.*;
importjava.util.*;
classWebserver{
publicstaticvoidmain(Stringarg[])throwsException
{
StringrequestMessageLine;
Stringfilename;
ServerSocketlistenSocket=newServerSocket(6789);
//创立一个倾听的套接口的对象
SocketconnectionSocket=listenSocket.accept();
//接受呼叫,创立一个传送数据的套接口,建立与客户端的虚拟管道
BufferedReaderinFromClient=newBufferedReader(newInputStreamReader(connectionSocket.getInputStream()));
//创立一个在connectionSocket上接收读取数据的对象
DataOutputStreamoutToClient=newDataOutputStream(connectionSocket.getOutputStream());
//创立一个在connectionSocket上写数据的对象
requestMessageLine=inFromClient.readLine();
StringTokenizertokenizerLine=newStringTokenizer(requestMessageLine);
if(tokenizerLine.nextToken().equals(GET)){
filename=tokenizerLine.nextToken();
//对文件名进行处理
if(filename.startsWith(/)==true)
filename=filename.substring(1);
Filefile=newFile(filename);
intnumOfBytes=(int)file.length();
FileInputStreaminFile=newFileInputStream(filename);
//检验翻开的文件名是否符合要求
byte[]fileInBytes=newbyte[numOfBytes];
inFile.read(fileInBytes);
outToClient.writeBytes(/1.0200DocumentFollows\r\n);
if(filename.endsWith(.jpg))
outToClient.writeByte
文档评论(0)