在 IFunctionInvocationFilter 中添加以下代码可以解决这个问题:
public Task OnExecuted(FunctionExecutedContext executedContext, CancellationToken cancellationToken) { if (executedContext.FunctionResult is OkObjectResult result) { var request = executedContext.FunctionExecutionContext?.HttpRequest; if (request != null && result.Value != null && request.Method.Equals(HttpMethods.Post)) { var requestBody = JsonSerializer.Serialize(request.Form, new JsonSerializerOptions { PropertyNamingPolicy = JsonNamingPolicy.CamelCase }); var responseBody = JsonSerializer.Serialize(result.Value); executedContext.FunctionResult = new OkObjectResult(new { RequestBody = requestBody, ResponseBody = responseBody }); } } return Task.CompletedTask; }
此代码中的关键是在执行后检查 FunctionResult,将其转换到 OkObjectResult 类型。而后我们将执行上下文的 HttpRequest 对象(如果存在)、使用 JsonSerializer 从表单提取请求体、使用 JsonSerializer 从结果获取响应体并将它们保存到返回的结果对象中。
这样,就可以确保在执行完函数之后不会丢失请求体了。
上一篇:AzureFunction-PowerShell-在AzureADB2C上调用Connect-MsolService出现TLS版本错误
下一篇:Azurefunctionapp教程:在NU1101处停止,无法找到包Microsoft.NET.Sdk.Functions。