c# – 在WCF中提供故障方法接收到没有详细信息的FaultException

前端之家收集整理的这篇文章主要介绍了c# – 在WCF中提供故障方法接收到没有详细信息的FaultException前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我为我的服务实现了一个IErrorHandler,如果授权错误,则需要返回403而不是400.
这就是我的ProvideFault方法的样子:
public void ProvideFault(Exception error,MessageVersion version,ref Message fault)
{
    if (((FaultException)error).Code.SubCode.Name == "FailedAuthentication")
    {
        WebOperationContext.Current.OutgoingResponse.StatusCode = HttpStatusCode.Forbidden;
        WebOperationContext.Current.OutgoingResponse.StatusDescription =
            "StatusCode is forced to change in order to have the correct response on authentication.";
    }
}

我想知道是否有任何方法可以为错误及其状态代码编写更好的检查,或者如何获得授权异常而不是FaultException女巫更通用?我觉得在FailedAuthentication字符串之后检查不太好,事实上它的授权不是认证…

解决方法

如果您使用的是C#6.0及更高版本,则可以使用 Exception Filters.示例为:
public string Example() 
{
   try
   {
      /* Method Logic */
      return string.Empty;
   }
   catch (System.Net.Http.HttpRequestException e) when (e.Message.Contains("400"))
   {
      return "unauthorized";
   }
}

在你的情况下:

public string Example() 
{
   try
   {
      /* Method Logic */
      return string.Empty;
   }
   catch (System.Net.Http.HttpRequestException e) when (e.Message.Contains("400"))
   {
      ProvideFault(e,"",e.Message);
   }
}

public void ProvideFault(System.Net.Http.HttpRequestException error,ref Message fault)
{
   /* your logic according to your needs. */
}

猜你在找的C#相关文章