博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
在global里捕获黄页并写入异常日志库
阅读量:7238 次
发布时间:2019-06-29

本文共 2213 字,大约阅读时间需要 7 分钟。

可以在global文件中的application_error()中,记录用户操作中出现的异常日志
None.gif
        
protected
 
void
 Application_Error(Object sender, EventArgs e)
ExpandedBlockStart.gifContractedBlock.gif    
dot.gif
{
InBlock.gif            
try
ExpandedSubBlockStart.gifContractedSubBlock.gif            
dot.gif{
InBlock.gif                Exception exception 
= HttpContext.Current.Server.GetLastError();
InBlock.gif                
// 如果有异常,则记录异常
InBlock.gif
                if (exception != null)
ExpandedSubBlockStart.gifContractedSubBlock.gif                
dot.gif{
InBlock.gif                    exception 
= exception.GetBaseException();
InBlock.gif                    log4net.ILog log 
= log4net.LogManager.GetLogger("ErrorLogFileAppender");
InBlock.gif    
InBlock.gif                    
//先注释掉,用于开发调试之用
InBlock.gif                    
// 保存异常记录
InBlock.gif
                    System.Text.StringBuilder errorMessage = new System.Text.StringBuilder();
InBlock.gif                    errorMessage.Append(Environment.NewLine);
InBlock.gif                    errorMessage.Append(
"异常消息:");
InBlock.gif                    errorMessage.Append(exception.Message);
InBlock.gif                    errorMessage.Append(Environment.NewLine);
InBlock.gif    
InBlock.gif                    errorMessage.Append(
"异常用户:");
InBlock.gif                    errorMessage.Append(Environment.NewLine);
InBlock.gif    
InBlock.gif                    errorMessage.Append(
"异常时间:");
InBlock.gif                    errorMessage.Append(System.DateTime.Now.ToString());
InBlock.gif                    errorMessage.Append(Environment.NewLine);
InBlock.gif    
InBlock.gif                    errorMessage.Append(
"异常位置:");
InBlock.gif                    errorMessage.Append(Environment.NewLine);
InBlock.gif                    errorMessage.Append(exception.StackTrace);
InBlock.gif                    errorMessage.Append(Environment.NewLine);
InBlock.gif
InBlock.gif                    OperationLogBL logBl 
= new OperationLogBL();
InBlock.gif                    OperationLogData data 
= new OperationLogData();
InBlock.gif                    data.OperateDate    
= DateTime.Now;
InBlock.gif                    data.OperatorId        
= CurrentUser.Info.UserID;
InBlock.gif                    data.OperatorName    
= CurrentUser.Info.UserName;
InBlock.gif                    data.OperatorEnName    
= CurrentUser.Info.UserNameEn;
InBlock.gif                    data.TypeNo            
= (int)Model.LogType.错误日志;
InBlock.gif                    data.Remark            
= errorMessage.ToString();
InBlock.gif                    data.ModifiedId        
= exception.Source;
InBlock.gif                    data.ModifiedItem    
= Request.UserHostAddress;
InBlock.gif                    data.OldValue        
= Request.RawUrl.ToString();
InBlock.gif                    logBl.Add(data);
ExpandedSubBlockEnd.gif                }
 // end if (exception != null)
ExpandedSubBlockEnd.gif
            }
InBlock.gif            
catch (Exception ex)
ExpandedSubBlockStart.gifContractedSubBlock.gif            
dot.gif{
InBlock.gif                System.Diagnostics.Debug.WriteLine(ex.Message);
ExpandedSubBlockEnd.gif            }
InBlock.gif                  
// 跳转至 [异常提示] 页面
InBlock.gif
                  if (ConfigurationSettings.AppSettings["EnableErrorPage"].ToLower() == "true")
ExpandedSubBlockStart.gifContractedSubBlock.gif                  
dot.gif{
InBlock.gif                    
string url = ConfigurationSettings.AppSettings["NoRightRedirect"];
InBlock.gif                    Response.Redirect(url);
ExpandedSubBlockEnd.gif                  }
ExpandedBlockEnd.gif        }

net的错误机制处理:

。<customErrors> 配置节支持内部 <error> 标记,该标记将 HTTP 状态代码与自定义错误页关联。例如:

None.gif
<
configuration
>
  
None.gif
<
system
.web
>
    
None.gif
<
customErrors 
mode
="RemoteOnly"
 defaultRedirect
="/genericerror.htm"
>
      
<
error 
statusCode
="500"
 redirect
="/error/callsupport.htm"
/>
      
<
error 
statusCode
="404"
 redirect
="/error/notfound.aspx"
/>
      
None.gif
<
error 
statusCode
="403"
 redirect
="/error/noaccess.aspx"
/>
    
</
customErrors
>
  
</
system.web
></
configuration
>
mode   

mode:指示自定义错误是启用、禁用还是只向远程计算机显示。值:On、Off、RemoteOnly(默认值)。 

你可能感兴趣的文章
mysql备份
查看>>
普元王轩:做好大数据治理,加速航空业数字化转型
查看>>
避繁就简为数据中心减负
查看>>
我的Android进阶之旅------&gt;Android字符串资源中的单引号问题error: Apostrophe not preceded by 的解决办法...
查看>>
2015 年度 Android 开发者必备的 5 个开源库
查看>>
GLUT Trackball Demo
查看>>
SQL集合操作符样例(UNION,INTERSECT,EXCEPT)
查看>>
Spark-SparkSQL深入学习系列十一(转自OopsOutOfMemory)
查看>>
JAVA Eclipse使用Maven构建web项目详解(SSM框架)
查看>>
高校银行协同 信息校园一卡通行
查看>>
论MongoDB索引选择的重要性
查看>>
建设互联网医疗的思考
查看>>
澄清云计算概念 解析云计算现状
查看>>
应对5G网络需求,G.metro技术逐步走向成熟和应用
查看>>
【LeetCode从零单排】No104 Maximum Depth of Binary Tree
查看>>
使用使用Zopfli优化PNG图片
查看>>
德扑 AI 之父托马斯·桑德霍姆:扑克 AI 如何完虐人类,和 AlphaGo 大不同
查看>>
最常用的四种大数据分析方法
查看>>
极进网络石奇海:向802.11ac技术智能迁移的八大考虑要素
查看>>
中央财经大学创新创业中心主任尚超:大数据技术在防范虚假发票中的应用
查看>>