添加Global.asax文件到您的asp.net項目和處理應用程序錯誤:
void Application_Error(object sender, EventArgs e)
{
Exception ex = Server.GetLastError();
string errorMessage = "Application Exception: " + ex.Message;
if (ex.InnerException != null)
{
errorMessage += Environment.NewLine + "Inner Exception: " + ex.InnerException.Message;
}
if (Context != null && Context.Request != null)
{
errorMessage += Environment.NewLine + "Absolute Url: " + Context.Request.Url.AbsolutePath;
}
Services.LoggerManager.Log(
Services.LoggerManager.eLogContext.Application,
Services.LoggerManager.eLogType.Error,
Context, errorMessage);
}
這裏是LoggerManager部分:
public static class LoggerManager
{
public enum eLogType
{
Information = 0,
Warning = 1,
Error = 2
}
public enum eLogContext
{
Application = 0,
Session = 1
}
/// <summary>
/// Method for logging custom message
/// </summary>
/// <param name="logContext"></param>
/// <param name="logType"></param>
/// <param name="context"></param>
/// <param name="message"></param>
public static void Log(eLogContext logContext, eLogType logType, HttpContext context, string message)
{
switch (logContext)
{
case eLogContext.Application:
//TODO: log application type event...
break;
case eLogContext.Session:
//TODO: log session type event...
break;
default:
throw new NotImplementedException("eLogContext '" + logContext.ToString() + "' is not implemented!");
}
}
}
如果我想一個警告可能我只是添加Application_Warning (對象發件人,EventArgs e)到global.asax? –
不是。 Global.asax不支持此事件。但是,您可以處理特定的asp.net頁面內的異常,然後調用LoggerManager.Log( Services.LoggerManager.eLogContext.Application, Services.LoggerManager.eLogType.Warning, Context,warningMessage); –
我想要說明一點,我必須在每次使用**的地方使用throw代碼**嘗試**和** catch ** –