0

我正在通过代码配置 REST WCF 服务,但有些地方不对劲。我使用如下代码创建了一个错误处理程序。

当我运行我们的服务(自托管)时,当我抛出带有未授权状态代码的 WebFaultException 时,ProvideFault 代码被命中。问题是客户端(浏览器)收到“服务器在处理请求时遇到错误。有关更多详细信息,请参阅服务器日志。” 知道我错过了什么吗?另外,由于我是自托管的,所以没有“服务器日志”,所以基本上我完全一无所知。无论如何要在自托管服务中捕获“服务器日志”?

注意:WebFaultException 是我们在使用 3.5 时编写的。

public class WebErrorHandler : IErrorHandler
{
    private IErrorHandler m_chainedHandler;

    public WebErrorHandler(IErrorHandler chainedHandler)
    {
        m_chainedHandler = chainedHandler;
    }

    #region IErrorHandler Members

    public bool HandleError(Exception error)
    {
        return m_chainedHandler.HandleError(error);
    }

    public void ProvideFault(Exception error, System.ServiceModel.Channels.MessageVersion version, ref System.ServiceModel.Channels.Message fault)
    {
        WebFaultException ex = error as WebFaultException;
        if (ex != null)
        {
            fault = Message.CreateMessage(version, "");
            HttpResponseMessageProperty p = new HttpResponseMessageProperty();
            p.StatusCode = ex.Status;
            p.StatusDescription = "Another test";

            fault.Properties.Add(HttpResponseMessageProperty.Name, p);
        }
        else
        {
            m_chainedHandler.ProvideFault(error, version, ref fault);
        }
    }

    #endregion
}
4

1 回答 1

0

如果你真的处理了错误,你应该从句柄错误中返回 true。调用嵌套的处理程序可能会导致错误被抛出。(如果链接的处理程序为 null,则链接调用将导致 NullReferenceException)。

于 2013-10-03T17:31:54.060 回答