1

TCPソケットを介してHTTPリクエストを送信し、応答としてヘッダーを取得していますが、コンテンツには疑問符しか含まれていません。それはどういうことですか?

これが私のコードです:

Socket sock = null;
OutputStream out = null;
InputStream in = null;

try {
    // open socket
    sock = new Socket(this.addr, this.port);

    // get output stream
    out = sock.getOutputStream();

    // create request
    StringBuffer request = new StringBuffer();
    request.append("GET " + this.uri + " HTTP/1.1").append(this.CRLF);
    request.append("Host: " + this.host).append(this.CRLF);
    request.append("Cache-Control: no-cache").append(this.CRLF);
    request.append("Connection: keep-alive").append(this.CRLF);
    request.append("User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_6_8) AppleWebKit/536.11 (KHTML, like Gecko) Chrome/20.0.1132.57 Safari/536.11").append(this.CRLF);
    request.append("Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8").append(this.CRLF);
    request.append("Accept-Encoding: gzip,deflate,sdch").append(this.CRLF);
    request.append("Accept-Language: en-GB").append(this.CRLF);
    request.append("Accept-Language: ISO-8859-1,utf-8;q=0.7,*;q=0.3").append(this.CRLF);
    request.append("Pragma: no-cache").append(this.CRLF);
    request.append(this.CRLF);

    // write request per byte for the lulz
    for(int i = 0; i < request.length(); i++) {
        out.write(request.toString().getBytes()[i]);
        System.out.print((char) request.toString().getBytes()[i]);
    }

    out.flush();

    // open inputstream
    in = sock.getInputStream();

    int inbyte;

    // read response per byte for the lulz
    while((inbyte = in.read()) > 0) {
        System.out.print((char) inbyte);
    }

    // close out, in and socket
    out.close();
    in.close();
    sock.close();
} catch (IOException e) {
    e.printStackTrace();
}

実際の出力は次のとおりですが、私のリクエストヘッダーを見ることができます。

GET / HTTP/1.1
Host: www.timseverien.nl
Cache-Control: no-cache
Connection: keep-alive
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_6_8) AppleWebKit/536.11 (KHTML, like Gecko) Chrome/20.0.1132.57 Safari/536.11
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Encoding: gzip,deflate,sdch
Accept-Language: en-GB
Accept-Language: ISO-8859-1,utf-8;q=0.7,*;q=0.3
Pragma: no-cache

そして最後に、応答:

HTTP/1.1 200 OK
Date: Fri, 13 Jul 2012 07:47:25 GMT
Server: Apache/2
X-Pingback: http://www.timseverien.nl/xmlrpc.php
Vary: Accept-Encoding,User-Agent
Content-Encoding: gzip
Content-Length: 2758
Keep-Alive: timeout=1, max=100
Connection: Keep-Alive
Content-Type: text/html; charset=UTF-8

?

ソースコードの代わりにこの疑問符が表示されるのはなぜですか?

4

2 に答える 2

4

Content-Encoding: gzip- 応答は圧縮されているため、画面に確実に出力できません。

ヘッダーから削除するAccept-Encodingと、プレーン テキストが表示されます。

http で遊びたい場合は、http/1.0 から始めてください。はるかに扱いやすいです。

于 2012-07-13T08:05:38.797 に答える
1

Bantharがすでに指摘しているように、コンテンツはgzipで圧縮されていますが、コンテンツの長さも2758バイトですが、読んだのは1つだけです。

InputStream.read()のjavadocsは次のように述べています。

bの長さがゼロの場合、バイトは読み取られず、0が返されます。それ以外の場合は、少なくとも1バイトを読み取ろうとします。ストリームがファイルの最後にあるために使用可能なバイトがない場合、値-1が返されます。それ以外の場合は、少なくとも1バイトが読み取られてbに格納されます。

>0のテストは間違っていると思います。

while((inbyte = in.read()) > 0) {

する必要があります:

while((inbyte = in.read()) >= 0) {

in.read()0〜255の範囲(バイトの全範囲)の値を返す場合があります。利用可能なデータがなくなると、 in.read()-1が返されます。これが、ではなくをin.read()返す理由です。intbyte

于 2012-07-13T08:12:04.783 に答える