Przykład, jak możesz to zrobić:
Kilka uwag:
LoggingHandler
przechwytuje żądanie, zanim je obsłuży, i HttpClientHandler
ostatecznie zapisze do drutu.
PostAsJsonAsync
Rozszerzenie wewnętrznie tworzy plik, ObjectContent
a gdy ReadAsStringAsync()
jest wywoływany w programie LoggingHandler
, powoduje, że program formatujący wewnątrz ObjectContent
serializuje obiekt i dlatego widzisz zawartość w formacie json.
Program obsługi logowania:
public class LoggingHandler : DelegatingHandler
{
public LoggingHandler(HttpMessageHandler innerHandler)
: base(innerHandler)
{
}
protected override async Task<HttpResponseMessage> SendAsync(HttpRequestMessage request, CancellationToken cancellationToken)
{
Console.WriteLine("Request:");
Console.WriteLine(request.ToString());
if (request.Content != null)
{
Console.WriteLine(await request.Content.ReadAsStringAsync());
}
Console.WriteLine();
HttpResponseMessage response = await base.SendAsync(request, cancellationToken);
Console.WriteLine("Response:");
Console.WriteLine(response.ToString());
if (response.Content != null)
{
Console.WriteLine(await response.Content.ReadAsStringAsync());
}
Console.WriteLine();
return response;
}
}
Połącz powyższy LoggingHandler z HttpClient :
HttpClient client = new HttpClient(new LoggingHandler(new HttpClientHandler()));
HttpResponseMessage response = client.PostAsJsonAsync(baseAddress + "/api/values", "Hello, World!").Result;
Wynik:
Request:
Method: POST, RequestUri: 'http://kirandesktop:9095/api/values', Version: 1.1, Content: System.Net.Http.ObjectContent`1[
[System.String, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089]], Headers:
{
Content-Type: application/json; charset=utf-8
}
"Hello, World!"
Response:
StatusCode: 200, ReasonPhrase: 'OK', Version: 1.1, Content: System.Net.Http.StreamContent, Headers:
{
Date: Fri, 20 Sep 2013 20:21:26 GMT
Server: Microsoft-HTTPAPI/2.0
Content-Length: 15
Content-Type: application/json; charset=utf-8
}
"Hello, World!"
new HttpClientHandler()
? Nie ma go w oficjalnej dokumentacji: docs.microsoft.com/en-us/aspnet/web-api/overview/advanced/…ProcessRequest
iProcessResponse
metody dla Ciebie przed i poSendAsync
wywołaniu.Zobacz http://mikehadlow.blogspot.com/2012/07/tracing-systemnet-to-debug-http-clients.html
Aby skonfigurować odbiornik System.Net do wysyłania zarówno do konsoli, jak i do pliku dziennika, dodaj następujące elementy do pliku konfiguracji zestawu:
źródło
<system.diagnostics>
do folderuapp.config
pod,<configuration>
ale wbin
folderze nie ma pliku dziennika, a dane wyjściowe konsoli również nic nie wyświetlają. Czego mi brakuje?initializeData
atrybucie zostanie utworzona w bieżącym katalogu roboczym uruchomionego pliku wykonywalnego, więc możesz chcieć sprawdzić, która ścieżka znajduje się w twoim środowisku.Śledzenie sieci jest również dostępne dla następnych obiektów (zobacz artykuł na msdn )
Umieść kolejne wiersze kodu w pliku konfiguracyjnym
źródło
Najłatwiejszym rozwiązaniem byłoby użycie Wireshark i prześledzenie przepływu HTTP tcp.
źródło