首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >不处理异常的IErrorHandler实现

不处理异常的IErrorHandler实现
EN

Stack Overflow用户
提问于 2012-07-13 18:45:56
回答 1查看 526关注 0票数 1

我有一个双工WCF服务,我正试图为它创建一个全局异常处理程序。

我已经按照this blog post为IErrorHandler实现创建了一个行为扩展

如果我在ApplyDispatchBehavior方法上设置一个断点,我可以看到我的处理程序被添加到通道调度器ErrorHandlers的属性中,但是如果我随后抛出异常,则既不会调用HandleError方法,也不会调用ProvideFault方法。

我的错误处理程序如下所示:

代码语言:javascript
复制
internal class ControlFrameworkErrorHandler : IErrorHandler, IServiceBehavior
{
    private static readonly ILog Logger = LogManager.GetLogger(typeof(ControlFrameworkWcfService));


    public bool HandleError(Exception error)
    {
        Logger.Fatal("An unhandled exception occurred:");
        Logger.Fatal(error.Message);
        Logger.Fatal(error.StackTrace);
        return true;
    }

    public void ProvideFault(Exception error, MessageVersion version, ref Message fault)
    {
    }

    public void Validate(ServiceDescription serviceDescription, ServiceHostBase serviceHostBase)
    {
    }

    public void AddBindingParameters(ServiceDescription serviceDescription, ServiceHostBase serviceHostBase, Collection<ServiceEndpoint> endpoints, BindingParameterCollection bindingParameters)
    {
    }

    public void ApplyDispatchBehavior(ServiceDescription serviceDescription, ServiceHostBase serviceHostBase)
    {
        IErrorHandler errorHandler = new ControlFrameworkErrorHandler();

        foreach (var channelDispatcherBase in serviceHostBase.ChannelDispatchers)
        {
            var channelDispatcher = channelDispatcherBase as ChannelDispatcher;
            if (channelDispatcher != null)
            {
                channelDispatcher.ErrorHandlers.Add(errorHandler);
            }
        }
    }
}

我的行为实现如下所示:

代码语言:javascript
复制
internal class ControlFrameworkErrorHandlerElement : BehaviorExtensionElement
{
    public override Type BehaviorType
    {
        get
        {
            return typeof(ControlFrameworkErrorHandler);
        }
    }

    protected override object CreateBehavior()
    {
        return new ControlFrameworkErrorHandler();
    }
}

我的App.config是这样的:

代码语言:javascript
复制
<?xml version="1.0" encoding="utf-8"?>
<configuration>
    <system.serviceModel>
       <services>
          <service name="ControlFrameworkService.ControlFrameworkWcfService" behaviorConfiguration="ControlFrameworkServiceBehavior">
           <host>
             <baseAddresses>
              <add baseAddress="http://localhost:8080/ControlFrameworkService/service" />
             </baseAddresses>
           </host>
        <endpoint address="" binding="wsDualHttpBinding" bindingConfiguration="WSDualHttpBinding_IControlFrameworkDuplex" contract="ControlFrameworkService.IControlFrameworkDuplex" />
        <endpoint address="mex" binding="mexHttpBinding" contract="IMetadataExchange" />
      </service>
    </services>
    <bindings>
      <wsDualHttpBinding>
        <binding name="WSDualHttpBinding_IControlFrameworkDuplex" closeTimeout="00:01:00" openTimeout="00:01:00" receiveTimeout="24.20:31:23.6470000" sendTimeout="24.20:31:23.6470000" bypassProxyOnLocal="false" transactionFlow="false" hostNameComparisonMode="StrongWildcard" maxBufferPoolSize="8388608" maxReceivedMessageSize="2147483647" messageEncoding="Mtom" textEncoding="utf-8" useDefaultWebProxy="true" clientBaseAddress="http://localhost:808/myClient/">
          <readerQuotas maxDepth="32" maxStringContentLength="8192" maxArrayLength="8388608" maxBytesPerRead="8388608" maxNameTableCharCount="8388608" />
          <reliableSession ordered="true" inactivityTimeout="24.20:31:23.6470000" />
          <security mode="None">
            <message clientCredentialType="None" />
          </security>
        </binding>
      </wsDualHttpBinding>
    </bindings>
    <extensions>
      <behaviorExtensions>
        <add name="ControlFrameworkErrorHandler" type="ControlFrameworkService.ControlFrameworkErrorHandlerElement, ControlFrameworkService, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null" />
      </behaviorExtensions>
    </extensions>
    <behaviors>
      <serviceBehaviors>
        <behavior name="ControlFrameworkServiceBehavior">
          <serviceMetadata httpGetEnabled="true" />
          <serviceDebug includeExceptionDetailInFaults="True" />
          <dataContractSerializer maxItemsInObjectGraph="2147483647" />
          <ControlFrameworkErrorHandler />
        </behavior>
      </serviceBehaviors>
    </behaviors>
    </system.serviceModel>
    <system.diagnostics>
      <trace autoflush="true">
      </trace>
      <sources>
        <source name="System.ServiceModel" switchValue="Information, ActivityTracing"      propagateActivity="true">
          <listeners>
            <add name="sdt" type="System.Diagnostics.XmlWriterTraceListener" initializeData="WcfDetailTrace.svclog" />
          </listeners>
        </source>
      </sources>
    </system.diagnostics>
</configuration>
EN

回答 1

Stack Overflow用户

发布于 2013-01-20 09:06:12

您应该将HandleError方法中的代码移到ProvideFault方法中。出于某些原因,尽管文档上说应该使用HandleError,但事实似乎并非如此。我遇到了与您相同的问题,我使用ProvideFault方法解决了这个问题。

我在互联网上读到过其他一些人也提出了同样的建议。

如果别人有更好的主意,我洗耳恭听。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/11468963

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档