Io so niente di SNP. Il tuo codice è un po 'confuso sulla parte di ricezione. Ho usato l'esempio seguente per inviare e leggere la risposta del server per una richiesta HTTP GET. Diamo prima un'occhiata alla richiesta e poi esaminiamo la risposta.
richiesta HTTP GET:
GET/HTTP/1.1
Host: 127.0.0.1
Connection: keep-alive
Accept: text/html
User-Agent: CSharpTests
string - "GET/HTTP/1.1\r\nHost: 127.0.0.1\r\nConnection: keep-alive\r\nAccept: text/html\r\nUser-Agent: CSharpTests\r\n\r\n"
Server intestazione della risposta HTTP:
HTTP/1.1 200 OK
Date: Sun, 07 Jul 2013 17:13:10 GMT
Server: Apache/2.4.4 (Win32) OpenSSL/0.9.8y PHP/5.4.16
Last-Modified: Sat, 30 Mar 2013 11:28:59 GMT
ETag: \"ca-4d922b19fd4c0\"
Accept-Ranges: bytes
Content-Length: 202
Keep-Alive: timeout=5, max=100
Connection: Keep-Alive
Content-Type: text/html
string - "HTTP/1.1 200 OK\r\nDate: Sun, 07 Jul 2013 17:13:10 GMT\r\nServer: Apache/2.4.4 (Win32) OpenSSL/0.9.8y PHP/5.4.16\r\nLast-Modified: Sat, 30 Mar 2013 11:28:59 GMT\r\nETag: \"ca-4d922b19fd4c0\"\r\nAccept-Ranges: bytes\r\nContent-Length: 202\r\nKeep-Alive: timeout=5, max=100\r\nConnection: Keep-Alive\r\nContent-Type: text/html\r\n\r\n"
ho volutamente ommited il corpo della risposta del server, perché sappiamo già che è esattamente 202 byte, come specificato per Content-Length nell'intestazione della risposta.
Un'occhiata alle specifiche HTTP rivelerà che un'intestazione HTTP termina con una nuova riga vuota ("\ r \ n \ r \ n"). Quindi dobbiamo solo cercarlo.
Vediamo un po 'di codice in azione. Assumere un socket variabile di tipo System.Net.Sockets.Socket.
socket = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp);
socket.Connect("127.0.0.1", 80);
string GETrequest = "GET/HTTP/1.1\r\nHost: 127.0.0.1\r\nConnection: keep-alive\r\nAccept: text/html\r\nUser-Agent: CSharpTests\r\n\r\n";
socket.Send(Encoding.ASCII.GetBytes(GETrequest));
Abbiamo inviato la richiesta al server, riceviamo e analizziamo correttamente la risposta.
bool flag = true; // just so we know we are still reading
string headerString = ""; // to store header information
int contentLength = 0; // the body length
byte[] bodyBuff = new byte[0]; // to later hold the body content
while (flag)
{
// read the header byte by byte, until \r\n\r\n
byte[] buffer = new byte[1];
socket.Receive(buffer, 0, 1, 0);
headerString += Encoding.ASCII.GetString(buffer);
if (headerString.Contains("\r\n\r\n"))
{
// header is received, parsing content length
// I use regular expressions, but any other method you can think of is ok
Regex reg = new Regex("\\\r\nContent-Length: (.*?)\\\r\n");
Match m = reg.Match(headerString);
contentLength = int.Parse(m.Groups[1].ToString());
flag = false;
// read the body
bodyBuff = new byte[contentLength];
socket.Receive(bodyBuff, 0, contentLength, 0);
}
}
Console.WriteLine("Server Response :");
string body = Encoding.ASCII.GetString(bodyBuff);
Console.WriteLine(body);
socket.Close();
Questo è probabilmente il metodo peggiore per fare questo in C#, ci sono tonnellate di classi per gestire le richieste HTTP e le risposte in .NET, ma ancora se avete bisogno, funziona.
C'è un motivo per cui è necessario utilizzare Socket anziché, ad esempio, "System.Net.Http.HttpClient"? –
o Webclient per quella materia ... – steveg89
Nessun motivo specifico. In realtà non ero a conoscenza di 'HttpCLient o Webclient'. Ma comunque mi piacerebbe capire cosa è il mio codice precedente. – RanRag