我正在通过代码配置 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
}