HttpWebRequest выдает System.Net.WebException Section = ResponseStatusLine - PullRequest
0 голосов
/ 23 января 2012

Я написал простой http-сервер, с которым планирую взаимодействовать с HttpRequest / Response. Сервер получает запрос и синтаксический анализ в порядке, но когда я пишу обратно, я получаю исключение

System.Net.WebException: Der Server hat eine Protokollverletzung ausgeführt. Section=ResponseStatusLine
   bei System.Net.HttpWebRequest.GetResponse()

мой серверный код, который пишет обратно

TcpClient client = ...;
_stream = _client.GetStream();


// make sure "\r\n" is used as line ending, because it may be different on different OS
_output = new StreamWriter(_stream, Encoding.UTF8) { NewLine = "\r\n" };

length = 0;
code = 200;
message = "OK";
_output.WriteLine("HTTP/1.1 " + code + " " + message);
_output.WriteLine("Server: My Server");
_output.WriteLine("ContentLength: " + length);
_output.WriteLine("Connection: " + (_keepAlive ? "Keep-Alive" : "Close"));
_output.WriteLine();
_output.Flush();

код клиента

var request = (HttpWebRequest)WebRequest.Create("http://127.0.0.1:8080/foo");
request.KeepAlive = false;
request.ServicePoint.Expect100Continue = false;

using (var res = request.GetResponse())   // throws here
{
}

есть идеи?

Обновление: как упоминал Джон, первая ошибка удалена, но все еще не работает

альтернативный код клиента

using (var client = new TcpClient())
{
    client.Connect(new IPEndPoint(IPAddress.Loopback, 8080));
    using (var stream = client.GetStream())
    {
        var writer = new StreamWriter(stream);
        writer.WriteLine("GET /foo HTTP/1.1");
        writer.WriteLine("HOST:127.0.0.1");
        writer.WriteLine("Connection:Close");
        writer.WriteLine();
        writer.Flush();

        var response = new StreamReader(stream).ReadToEnd();
        foreach (var c in response)
        {
            if (char.IsControl(c))
                Console.Write("'{0}'" , (int)c);
            else
                Console.Write(c);
        }
    }
}

возвращает

HTTP/1.1 200 OK'13''10'Server: My custom Server'13''10'ContentLength: 0'13''10'Connection: Close'13''10''13''10'

1 Ответ

1 голос
/ 23 января 2012

Ну, это очень подозрительно, чтобы начать с:

_output = new StreamWriter(_stream, Encoding.UTF8) { NewLine = "\n\r" };

Я думаю, вы имели в виду \r\n, а не \n\r.

...