Пример того, как вы могли бы это сделать:
Некоторые примечания:
LoggingHandler
перехватывает запрос до того, как обработает его, HttpClientHandler
который, наконец, записывает в провод.
PostAsJsonAsync
extension внутренне создает, ObjectContent
и когда ReadAsStringAsync()
вызывается в LoggingHandler
, оно заставляет средство форматирования внутри ObjectContent
сериализовать объект, и это причина, по которой вы видите содержимое в json.
Обработчик журнала:
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;
}
}
Свяжите вышеуказанный LoggingHandler с HttpClient :
HttpClient client = new HttpClient(new LoggingHandler(new HttpClientHandler()));
HttpResponseMessage response = client.PostAsJsonAsync(baseAddress + "/api/values", "Hello, World!").Result;
Вывод:
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()
? Его нет в официальных документах: docs.microsoft.com/en-us/aspnet/web-api/overview/advanced/…ProcessRequest
иProcessResponse
метод для вас до и послеSendAsync
вызова.См. Http://mikehadlow.blogspot.com/2012/07/tracing-systemnet-to-debug-http-clients.html
Чтобы настроить прослушиватель System.Net для вывода как в консоль, так и в файл журнала, добавьте в файл конфигурации сборки следующее:
источник
<system.diagnostics>
вapp.config
рамках ,<configuration>
но вbin
папке нет файла журнала и вывод на консоль ничего не показывать тоже, что мне не хватает?initializeData
атрибуте, будет создано в текущем рабочем каталоге исполняемого файла, который вы запускаете, поэтому вы можете проверить, какой путь находится в вашей среде.Также доступна сетевая трассировка для следующих объектов (см. Статью о msdn )
Поместите следующие строки кода в файл конфигурации
источник
Самым простым решением было бы использовать Wireshark и отслеживать поток HTTP tcp.
источник