SSD8 exercise01

    新的一学期 又带去回了SSD8,网络与分布式课程。今年开始改革了,因此咱们助教要一个一个查做业。而后我就陷入了一场帮别人圆谎的博弈赛中。有鉴于此,我就几个关键点对SSD8 exercise01关键点进行描述。首先FTP里面有个wireshark-setup-1.0.8.exe的软件,你们不妨打开看看,这个wireshark的抓包工具的教程网上一搜一堆,你们能够看下。html

先说说这个题是干吗的,你要完成三个类java

1 Client.java,这个类就是模拟一个HTTP的客户端,发出“请求报文”,解析“响应报文”。ajax

2 SimpleServer.java这个类是模拟一个HTTP的服务器,解析“请求报文”,向Client.java返回“响应报文”。数组

3 多线程的HTTP服务器,响应并发的Client.java可是以现有的实验室资源无法测试,你也能够写个ThreadClient.java来试试。服务器

 HTTP的请求报文张这样:网络

GET /enclosure/2010-09-10T02_51_05-07_00.mp3 HTTP/1.1 多线程

Host: 805665086.podomatic.com Connection: keep-alive 并发

User-Agent: Mozilla/5.0 (X11; Linux i686) AppleWebKit/535.7 (KHTML, like Gecko) Chrome/16.0.912.77 Safari/535.7 app

Accept: */*框架

Referer: http://www.1g1g.com/player/loader.swf?uid=0.8106261373031884

Accept-Encoding: gzip,deflate,sdch Accept-Language: en-US,en;q=0.8

Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.3
[不要忘了这有空行或者CRLF]

HTTP的响应报文张这样:

 HTTP/1.1 200 OK 

Server: XNHttpServer1.0
Content-Type: text/html;charset=UTF-8
Content-Length: 79
Connection: keep-alive
Keep-Alive: 300
Cache-Control: no-cache
Expires: Thu, 01 Jan 1970 00:00:00 GMT
[不要忘了这有空行或者CRLF,分割了报文头和报文体]
<msglist><message type='system'><body>init ajax loop</body></message></msglist>

那么如今开始程序方面的问题。

Client.java代码框架大概是这样。

建立Socket;

socket = new Socket(host, PORT);

打开链接到Socket的输入/出流;

ostream = new BufferedOutputStream(socket.getOutputStream());
istream = new BufferedInputStream(socket.getInputStream());

 下面开始最最重要的步骤就是发出“请求报文”,解析“响应报文”。

这里是检查的重点

首先你要拼出请求报文的请求行

长这样GET /index.html HTTP/1.1[crlf][crlf]

这样就足够了,有的同窗把首部行也拼了出来,也没错,可是工做量上去了。这样其实就能够了socket就能够帮你把你的“请求报文”发送到服务器段的host上去了。

还记得当时你打开socket的ostream吗?用它来发送就行。以上面的为例

ostream.write(buffer, 0, request.length());
ostream.flush();

就能够发送了。不一样的流有不一样的方法,具体查看JDK。

下面解析“响应报文”。

你要得到一段流,输入流,哪来的本身找去。我从网上找了一段很精妙的代码,各位看官看看。

                boolean inHeader = true; // loop control
        char c = 0;
        while (inHeader && ((c = istream.read()) != -1)) {
            switch (c) {
            case '\r':
                break;
            case '\n':
                if (c == last) {
                    inHeader = false;
                    break;
                }
                last = c;
                header.append("\n");
                break;
            default:
                last = c;
                header.append((char) c);
            }
        }

引入标志位inHeader来记录当前是否是在解析响应报文头。同时断定是否是有两个连续的crlf。

再来你就把剩下的东东报文体就是直接保存在一个byte数组或者String中就能够了。

最后不要忘了关闭SOCKET。

 

SimpleServer端和Client反过来了,你们能够尝试一下。本身写写,切记报文处理逻辑和SOCKET是考察重点。

相关文章
相关标签/搜索