5

我在为我的 WCF 服务配置 ServiceBehavior 时遇到问题。

一些背景。基本上我正在开发一个应该在 IIS 上运行的 REST 服务 WCF。我需要能够记录服务抛出的异常(我正在使用 log4net)并根据异常类型返回 HTTP 状态代码。我希望我的服务实现对 WCF 相关的东西有最少的了解,所以我不想在服务中的任何地方都将异常转换为 FaultException。所以我发现将我自己的 IErrorHandler 添加到服务主机将是最好的方法。

然而,我的问题是,无论我尝试什么,我似乎都无法在 Web.config 中获得我的自定义 ServiceBehavior 的配置。这是相关的代码。

网络配置。

<system.webServer>
  <modules runAllManagedModulesForAllRequests="true">
    <add name="UrlRoutingModule" type="System.Web.Routing.UrlRoutingModule, System.Web, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a" />
  </modules>
</system.webServer>

<system.serviceModel>
  <behaviors>
    <serviceBehaviors>
      <behavior name="UsingErrorLogBehavior">
        <errorLogBehavior/>
      </behavior>
    </serviceBehaviors>
    <endpointBehaviors>
      <behavior>
        <webHttp/>
      </behavior>
    </endpointBehaviors>
  </behaviors>
  <extensions>
    <behaviorExtensions>
      <add name="errorLogBehavior"
           type="MyNameSpace.Web.ErrorExtensionElement, MyNameSpace.Web"/>
    </behaviorExtensions>
  </extensions>
  <serviceHostingEnvironment aspNetCompatibilityEnabled="true"/>
  <standardEndpoints>
    <webHttpEndpoint>
      <standardEndpoint name="" helpEnabled="true" 
                        automaticFormatSelectionEnabled="false" 
                        defaultOutgoingResponseFormat="Json" 
                        maxReceivedMessageSize="4194304" transferMode="Buffered" />
    </webHttpEndpoint>
  </standardEndpoints>
</system.serviceModel>

错误扩展元素。

namespace MyNameSpace.Web
{
    public class ErrorExtensionElement : BehaviorExtensionElement
    {
        public override Type BehaviorType
        {
            get { return typeof(ErrorServiceBehavior); }
        }

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

错误服务行为。

namespace MyNameSpace.Web
{
    public class ErrorServiceBehavior : IServiceBehavior
    {
        public void AddBindingParameters(ServiceDescription serviceDescription, System.ServiceModel.ServiceHostBase serviceHostBase, System.Collections.ObjectModel.Collection<ServiceEndpoint> endpoints, System.ServiceModel.Channels.BindingParameterCollection bindingParameters)
        {
        }

        public void ApplyDispatchBehavior(ServiceDescription serviceDescription, System.ServiceModel.ServiceHostBase serviceHostBase)
        {
            foreach (ChannelDispatcher channelDispatcher in serviceHostBase.ChannelDispatchers)
            {
                channelDispatcher.ErrorHandlers.Add(new ExceptionModule());
            }
        }

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

ExceptionModule 实现 IErrorHandler 的地方。

4

1 回答 1

2

您有一个<serviceBehavior>名为“UsingErrorLogBehavior”的部分,但没有服务配置引用该部分。您可以将该部分设置为默认服务行为(通过不给它命名,就像您为端点行为所拥有的那样),或者<service>为您的服务添加一个引用该行为的元素:

<services>
  <service name="YourNamespace.YourServiceName"
           behaviorConfiguration="UsingErrorLogBehavior">
    <endpoint address=""
              binding="webHttpBinding"
              contract="YourNamespace.YourContractName" />
  </service>
</services>
于 2012-11-22T17:32:55.170 回答