Gibt es eine Möglichkeit, um get-request-body in .NET Core FilterAttribute?

Beispiel meiner Anfrage

http://localhost:8065/api/note
POST
content-type:application/json
request body: { "id" : "1234", "title" : "test", "status" : "draft"}

und die Antwort sollte

{ "msg" : "ok", "code" : 1}

Die Aktion

public async Task<IActionResult> Post([FromBody]NoteModel model)

Haben, um jede Anfrage protokolliert automatisch erstelle ich ein Attribut um diesen job zu machen. Das Attribut sieht wie folgt aus: (aus Microsoft Docs)

public class SampleActionFilterAttribute : TypeFilterAttribute
{
    public SampleActionFilterAttribute():base(typeof(SampleActionFilterImpl))
    {
    }

    private class SampleActionFilterImpl : IActionFilter
    {
        private readonly ILogger _logger;
        public SampleActionFilterImpl(ILoggerFactory loggerFactory)
        {
            _logger = loggerFactory.CreateLogger<SampleActionFilterAttribute>();
        }

        public void OnActionExecuting(ActionExecutingContext context)
        {

        }

        public void OnActionExecuted(ActionExecutedContext context)
        {
            _logger.LogDebug("[path]" + context.HttpContext.Request.Path);
            _logger.LogDebug("[method]" + context.HttpContext.Request.Method);
            _logger.LogDebug("[body]"); //log request body, expectation: { "id" : "1234", "title" : "test", "status" : "draft"}
            _logger.LogDebug("[statuscode]" + context.HttpContext.Response.StatusCode);
            _logger.LogDebug("[response]"); //log response
        }
    }
}

Ich versuche es mal mit streamReader zu erhalten Wunsch Körper bekommen nur leere Zeichenfolge.

StreamReader reader = new StreamReader(context.HttpContext.Request.Body);
string text = reader.ReadToEnd();

Ist, dass, weil der Körper zum Lesen [fromBody] vom controller, so dass der stream kann nicht gelesen werden zweimal? Wenn ja, wie soll ich denn get-request-body und eine Antwort auf die OnActionExecuted Methode?


Update:

Habe ich nur kopiert, Legen Sie den code in meinem Projekt nicht funktioniert. Hier ist die debug-gifGibt es eine Möglichkeit, um get-request-body in .NET Core FilterAttribute?

InformationsquelleAutor wtf512 | 2017-08-04
Schreibe einen Kommentar