我正在尝试在我的 WCF 服务中实现一个 IErrorHandler,以便在将其传递给客户端之前记录每个到达服务边界的异常。我已经使用 IErrorHandlers 将 Exceptions 转换为类型化的 FaultExceptions,这非常有用。根据 IErrorHandler.HandleError() 的 MSDN,它还旨在用于边界处的日志记录。
问题是,不能保证在操作线程上调用 HandleError 函数,所以我不知道如何获取有关哪些操作触发了异常的信息。我可以从异常本身中获取 TargetSite,但这给了我内部方法而不是操作。我还可以解析 StackTrace 字符串以找出它被抛出的位置,但这似乎有点脆弱和做作。在 HandleError 函数中是否有任何一致的、受支持的方式来获取任何状态信息(消息、操作描述等)?或任何其他自动记录服务调用异常的方法?
我正在寻找一种使用我现有的日志框架在生产中实施的解决方案,所以 SvcTraceViewer 不会为我做这件事。
谢谢。