WCF HTTP / SOAP Webservice - Возвращение сообщения об исключении в случае неисправности - PullRequest
1 голос
/ 16 мая 2011

У меня есть простой веб-сервис WCF HTTP / SOAP, реализация сервиса выглядит примерно так:

public CustomResponse DoSomething(CustomRequest request)
{
    try
    {
        return InternalGubbins.WithErrorHandling.ProcessRequest(request);
    }
    catch
    {
        // Some sort of error occurred that is not gracefully
        // handled elsewhere in the framework
        throw new SoapException("Hmmm, it would seem that the cogs are meshed!", SoapException.ServerFaultCode);
    }
}

Теперь, если выброшено исключение SoapException, я бы хотел, чтобы сообщение об исключении (т. Е. Hmmm, it would seem that the cogs are meshed!)будет возвращен вызывающему клиенту без каких-либо дополнительных сведений об исключении (т. е. трассировки стека).

Если я установлю includeExceptionDetailInFaults в значение true (web.config на сервере), то полное исключение со следами стека и т. д.вернуться к клиенту.Однако, если установить значение false, я получу общее сообщение:

Серверу не удалось обработать запрос из-за внутренней ошибки.Для получения дополнительной информации об ошибке либо включите IncludeExceptionDetailInFaults (либо из ServiceBehaviorAttribute, либо из поведения конфигурации) на сервере, чтобы отправить информацию об исключении обратно клиенту, либо включите трассировку в соответствии с документацией Microsoft .NET Framework 3.0 SDK.и проверьте журналы трассировки сервера.

Итак, вопрос в том, как я могу вернуть свое сообщение SoapException обратно вызывающему клиенту?т.е.:

<s:Envelope xmlns:s="http://www.w3.org/2003/05/soap-envelope" xmlns:a="http://www.w3.org/2005/08/addressing">
    <s:Header>
        <a:Action s:mustUnderstand="1">http://schemas.microsoft.com/net/2005/12/windowscommunicationfoundation/dispatcher/fault</a:Action>
        <a:RelatesTo>urn:uuid:185719f4-6113-4126-b956-7290be375342</a:RelatesTo>
    </s:Header>
    <s:Body>
        <s:Fault>
            <s:Code>
                <s:Value>s:Receiver</s:Value>
                <s:Subcode>
                    <s:Value xmlns:a="http://schemas.microsoft.com/net/2005/12/windowscommunicationfoundation/dispatcher">a:InternalServiceFault</s:Value>
                </s:Subcode>
            </s:Code>
            <s:Reason>
                <s:Text xml:lang="en-GB">Hmmm, it would seem that the cogs are meshed!</s:Text>
            </s:Reason>
        </s:Fault>
    </s:Body>
</s:Envelope>

Ответы [ 2 ]

2 голосов
/ 16 мая 2011

Я думаю, вам нужно объявить FaultContract для операции и использовать FaultException (SoapException является предварительным WCF). Я считаю, что WCF не отправляет ошибки клиенту, если они не являются частью договора на обслуживание. Я никогда не пробовал SoapException, но, безусловно, создание FaultException всегда работало хорошо для меня.

[ServiceContract()]    
public interface ISomeService
{
     [OperationContract]
     [FaultContract(typeof(MyFault))]
     CustomResponse DoSomething(CustomRequest request)
}

public class SomeService
{
    public CustomResponse DoSomething(CustomRequest request)
    {
        ...
        throw new FaultException<MyFault>(new MyFault());
    }
}
1 голос
/ 16 мая 2011

Если вы не хотите определять пользовательский тип исключения, попробуйте это

try    
{        
    return InternalGubbins.WithErrorHandling.ProcessRequest(request);    
}    
catch    
{
    throw new FaultException("Hmmm, it would seem that the cogs are meshed.");    
}

В таком случае клиент отправит следующий ответ

<s:Envelope xmlns:s="http://schemas.xmlsoap.org/soap/envelope/">
  <s:Header />
  <s:Body>
    <s:Fault>
      <faultcode>s:Client</faultcode>
      <faultstring xml:lang="en-US">Hmmm, it would seem that the cogs are meshed.</faultstring>
    </s:Fault>
  </s:Body>
</s:Envelope>
...