gpt4 book ai didi

error-handling - CRM 2011 - ITracingService 在运行时访问 traceInfo

转载 作者:行者123 更新时间:2023-12-03 08:30:02 25 4
gpt4 key购买 nike

我的插件中有一些自定义日志记录,并希望在我的自定义日志记录中包含我的 trackingService 的内容(在插件完成之前在 catch block 中调用)。

我似乎无法访问tracingService 的内容。我想知道它是否可以访问?

我尝试了 trackingService.ToString() 以防开发人员提供了一个有用的重载,唉,正如预期的那样,我得到了类“Microsoft.Crm.Sandbox.SandboxTracingService”的名称。

显然,Dynamics CRM 在需要时会在管道末端使用 trackingService 内容。

有人对此有任何想法吗?

亲切的问候,
加里

最佳答案

跟踪服务在执行期间不提供对跟踪文本的访问,但可以通过创建您自己的 ITracingService 实现来克服。 .请注意,您无法获得在 Execute 之前写入跟踪日志的任何文本。调用插件的方法 - 这意味着如果您有多个插件触发,您将不​​会在引发异常的插件中获得它们的跟踪输出。

    public class CrmTracing : ITracingService
{
ITracingService _tracingService;
StringBuilder _internalTrace;

public CrmTracing(ITracingService tracingService)
{
_tracingService = tracingService;
_internalTrace = new StringBuilder();
}

public void Trace(string format, params object[] args)
{
if (_tracingService != null) _tracingService.Trace(format, args);
_internalTrace.AppendFormat(format, args).AppendLine();
}

public string GetTraceBuffer()
{
return _internalTrace.ToString();
}
}

只需在您的插件中通过提供的 CRM 实例化它 ITracingService .因为它是同一个接口(interface),所以如果你将它传递给其他类和方法,它的工作原理是一样的。

public class MyPlugin : IPlugin
{

public void Execute(IServiceProvider serviceProvider)
{
var tracingService = new CrmTracing((ITracingService)serviceProvider.GetService(typeof(ITracingService)));

tracingService.Trace("Works same as always.");

var trace = tracingService.GetTraceBuffer();
}
}

关于error-handling - CRM 2011 - ITracingService 在运行时访问 traceInfo,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28091438/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com