问题描述
对于 4.8 之前的所有 .Net 版本,可以使用 IEndpointBehavior / IClientMessageInspector
轻松捕获使用 WCF 使用的 SOAP 服务的所有传入和传出流量,用于记录目的,如下所述,例如:{{3 }}
我想知道如何恢复它,或者在 .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;
}
要使其正常工作,您需要使用 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 的这些建议,但它现在有效!