AFr*_*act 4 .net c# wcf .net-4.0 .net-5
对于 4.8 之前的所有 .Net 版本,可以使用 WCF 轻松捕获用于日志记录目的的 SOAP 服务的所有传入和传出流量,IEndpointBehavior / IClientMessageInspector如下所述,例如: https: //learn.microsoft.com/en -us/dotnet/api/system.servicemodel.dispatcher.iclientmessageinspector.beforesendrequest?view=netframework-4.8
我想知道如何恢复此状态,或者在 .Net 5.0 中实现与以前相同的目的。我需要在日志文件中跟踪所有 SOAP 交换,以前我只需要做:
public void AfterReceiveReply(ref System.ServiceModel.Channels.Message reply, object correlationState)
{
_logger.Debug("Reply received: " + Environment.NewLine + "{0}", reply.ToString());
}
public object BeforeSendRequest(ref System.ServiceModel.Channels.Message request, IClientChannel channel)
{
_logger.Debug("Sending request: " + Environment.NewLine + "{0}", request.ToString());
return null;
}
Run Code Online (Sandbox Code Playgroud)
要使其正常工作,您需要 clientRuntime.MessageInspectors 和 client.Endpoint.Behaviors 来注册类。
尽管我已经注册了可用于 System.ServiceModel 的 nuget 包,尤其是 System.ServiceModel.Primitives.dll,但这些属性似乎不再存在。
事实上,这些功能仍然存在,而且看起来就像以前一样。属性只是略有改变。
client.Endpoint.Behaviors.Add(new LoggerEndpointBehavior(_logger));成为client.Endpoint.EndpointBehaviors.Add(new LoggerEndpointBehavior(_logger));
和
clientRuntime.MessageInspectors.Add(new LoggerClientMessageLoggerInspector(_logger));
成为clientRuntime.ClientMessageInspectors.Add(new LoggerClientMessageLoggerInspector(_logger));
其他一切都与第一个链接中的示例类似。我很惊讶在迁移时没有看到 Intellisense 的这些建议,但现在它可以工作了!