Un exemple de la façon dont vous pourriez faire ceci:
Quelques notes:
LoggingHandler
intercepte la requête avant de la traiter, HttpClientHandler
qui écrit finalement sur le fil.
PostAsJsonAsync
L'extension crée en interne un ObjectContent
et quand ReadAsStringAsync()
est appelé dans le LoggingHandler
, cela amène le formateur à l'intérieur ObjectContent
à sérialiser l'objet et c'est la raison pour laquelle vous voyez le contenu dans json.
Gestionnaire de journalisation:
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;
}
}
Chaîne le LoggingHandler ci-dessus avec HttpClient :
HttpClient client = new HttpClient(new LoggingHandler(new HttpClientHandler()));
HttpResponseMessage response = client.PostAsJsonAsync(baseAddress + "/api/values", "Hello, World!").Result;
Production:
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()
? Il n'est pas présent dans la documentation officielle: docs.microsoft.com/en-us/aspnet/web-api/overview/advanced/…ProcessRequest
andProcessResponse
pour vous avant et après l'SendAsync
appel.Voir http://mikehadlow.blogspot.com/2012/07/tracing-systemnet-to-debug-http-clients.html
Pour configurer un écouteur System.Net pour générer une sortie vers la console et un fichier journal, ajoutez ce qui suit à votre fichier de configuration d'assembly:
la source
<system.diagnostics>
enapp.config
sous<configuration>
mais dans lebin
dossier il n'y a pas de fichier journal et la sortie de la console ne pas afficher quoi que ce soit aussi, qu'est - ce que je manque?initializeData
attribut sera créé dans le répertoire de travail actuel de l'exécutable que vous exécutez, vous voudrez peut-être vérifier le chemin qui se trouve dans votre environnement.Suivi de réseau également disponible pour les objets suivants (voir l'article sur msdn )
Mettez les lignes de code suivantes dans le fichier de configuration
la source
La solution la plus simple serait d'utiliser Wireshark et de tracer le flux HTTP tcp.
la source