我正在通过代码配置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
}
答案 0 :(得分:0)
如果您实际处理错误,则应从句柄错误返回true。调用嵌套的处理程序可能会导致抛出错误。 (如果链式处理程序为null,则链式调用将导致NullReferenceException)。