ASP.NET Application_Error错误日志写入

时间:2022-08-29 09:08:01

一个web项目开发已完成,测试也通过,但是,bug是测不完的,特别是在一个大的网络环境下。那么,我们就应该记录这些错误,然后改正。这里,我的出错管理页面是在global.asax里面的,利用里面的Application_Error函数。

Global.asax代码:
<%@ Application Language="C#" %>
 
<script runat="server">
 
    void Application_Start(object sender, EventArgs e) 
    {
        // 在应用程序启动时运行的代码
 
    }
    
    void Application_End(object sender, EventArgs e) 
    {
        //  在应用程序关闭时运行的代码
 
    }
        
    void Application_Error(object sender, EventArgs e) 
    { 
        // 在出现未处理的错误时运行的代码
       // 在出现未处理的错误时运行的代码         
            Exception objErr = Server.GetLastError().GetBaseException();
            string error = string.Empty;
            string errortime = string.Empty;
            string erroraddr = string.Empty;
            string errorinfo = string.Empty;
            string errorsource = string.Empty;
            string errortrace = string.Empty;
 
            error += "发生时间:" + System.DateTime.Now.ToString() + "<br>";
            errortime = "发生时间:" + System.DateTime.Now.ToString();
 
            error += "发生异常页: " + Request.Url.ToString() + "<br>";
            erroraddr = "发生异常页: " + Request.Url.ToString();
 
            error += "异常信息: " + objErr.Message + "<br>";
            errorinfo = "异常信息: " + objErr.Message; 
 
            errorsource = "错误源:" + objErr.Source;
            errortrace = "堆栈信息:" + objErr.StackTrace;
            error += "--------------------------------------<br>";
            Server.ClearError();
            Application["error"] = error;
 
            //独占方式,因为文件只能由一个进程写入.
           System.IO.StreamWriter writer=null;
            try
            {               
                lock (this)
                {
                    // 写入日志
                    string year = DateTime.Now.Year.ToString();
                    string month = DateTime.Now.Month.ToString();
                    string path = string.Empty;
                    string filename = DateTime.Now.Day.ToString() + ".html";
                    path = Server.MapPath("~/ErrorLog/") + year + "/" + month;
                    //如果目录不存在则创建
                    if (!System.IO.Directory.Exists(path))
                    {
                        System.IO.Directory.CreateDirectory(path);
                    }
                    System.IO.FileInfo file = new System.IO.FileInfo(path + "/"+filename);        
                   
 
                    //文件不存在就创建,true表示追加
 
                    writer = new System.IO.StreamWriter(file.FullName, true);
 
                    string ip = "用户IP:" + Request.UserHostAddress;
                    string line = "-----------------------------------------------------";
 
                    string log = "<p style='font-size:9pt;'><br>" + line + "<br><font color=red>" + errortime + "&nbsp;&nbsp;" + erroraddr + "</font><br><font color=green>" + "<br/>" + ip + errorinfo + "<br>" + errorsource + "<br>" + errortrace.Replace("\r\n", "<br>") + "</font></p>";
                    writer.WriteLine(log);         
 
                   }
            }
            finally 
            {
                if (writer != null)
                    writer.Close();
                    
            }    
            Response.Redirect("~/ErrorPage.aspx");
 
    }
 
    void Session_Start(object sender, EventArgs e) 
    {
        // 在新会话启动时运行的代码
 
    }
 
    void Session_End(object sender, EventArgs e) 
    {
        // 在会话结束时运行的代码。 
        // 注意: 只有在 Web.config 文件中的 sessionstate 模式设置为
        // InProc 时,才会引发 Session_End 事件。如果会话模式设置为 StateServer 
        // 或 SQLServer,则不会引发该事件。
 
    }
       
</script>
 
显示出错信息的页面

ErrorPage.aspx代码:

<%@ Page
Language="C#" CodeFile="ErrorPage.aspx.cs"
Inherits="ErrorPage" %>
 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0
Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
 
<html xmlns="http://www.w3.org/1999/xhtml"
>
<head runat="server">
   
<title>无标题页</title>
<script language="javascript"
type="text/javascript">
// <!CDATA[
 
 
// ]]>
</script>
</head>
<body>
    <form
id="form1" runat="server">
   
<div>
     
  <table width="600" border="0"
align="center" cellpadding="1"
cellspacing="0">
<tr>
<td  class="table_bgcolor"
style="height: 138px">
<table width="100%" border="1" cellpadding="5"
cellspacing="0" class="table_bordercolor">
<tr bgcolor="#e4e4e4">
<td class="table_title" style="height:
22px"><STRONG><FONT
color="red">发生问题:</FONT></STRONG></td>
</tr>
<tr>
<td height="22">
<table cellSpacing="0" cellPadding="0"
width="100%" border="0">
<tr>
<td height="22">
<asp:Label id="lblMsg" runat="server"
Width="100%"></asp:Label>
</td>
</tr>
</table>
</td>
</tr>
<tr>
<td style="height: 22px">
<div align="center">
<asp:Button ID="Button1" Text="返 回"
style="WIDTH: 100p" runat="server" OnClick="Button1_Click"
/>
</td>
</tr>
</table>
</td>
</tr>
</table>
   
</div>
   
</form>
</body>
</html>
 
 

ErrorPage.aspx.cs

protected
void Page_Load(object sender, EventArgs e)
    {
       
if (!Page.IsPostBack)
       
{
           
lblMsg.Text = Application["error"].ToString() +
"<p>该信息已被系统记录,请稍候重试或与管理员联系。";
           
Server.ClearError();
       
}
    }
    protected
void Button1_Click(object sender, EventArgs e)
    {
       
Response.Redirect("~/Login.aspx");
    }

application_error是为了捕获那些未处理的异常,没有想到的异常

try...catch...还是需要的,为了精确定位错误的类型及信息,提出精确的提醒信息。

地址:http://blog.sina.com.cn/s/blog_6edd5506010190yh.html

ASP.NET Application_Error错误日志写入的更多相关文章

  1. asp&period;net 添加错误日志

    在开发程序中,错误日志很有必要.今天就把使用到的添加错误日志,记录下来,方便以后查看 利用的asp.net错误处理机制 Application_Error 贴出代码 protected void Ap ...

  2. ASP&period;NET - 记录错误日志

    不需要像log4net/Nlog/Common Logging配置,简单好用. 不用增加声明logger对象,可记录当前执行状况. 可以定义 维护功能模板的开发人员,以便用功能模块对于开发人员. 出处 ...

  3. asp&period;net Log4Net错误日志个人总结

    1)创建Global.asax protected void Application_Start(object sender, EventArgs e) { log4net.Config.XmlCon ...

  4. ASP&period;NET记录错误日志的方式

    程序记录错误日志是一种看起来对一般用户没什么作用,但对程序开发者用处很大的东西,它能查出错误或异常的程序马迹.那么,常用的记录错误日志的方式有哪些呢? 大多数情况下使用的是 1.直接记录为txt/xm ...

  5. 手把手教你,C&num;&period;Net如何用Log4net把错误日志写入到SQLite数据库中

    在项目中,我们往往会有把错误日志记录下来的习惯,这样有利于当网站发布后,能第一时间找到错误的所在地,以及错误的原因,以便于我们第一时间纠错.往往我们会把错误日志直接写到txt文本中,虽然操作简单,但是 ...

  6. 错误日志写入到本地磁盘(lock 队列)

    今天照常在b站上看看编程:看到有讲错误日志处理的,自己没写过日志,就看看了看: 主要是在讲的时候牵扯到了队列和lock的知识点:这方面知识自己了解的更少,那就记录一下.

  7. asp&period;net错误日志写入

    当我们一个web项目开发已完成,测试也通过了后,就把他放到网上去,但是,bug是测不完的,特别是在一个大的网络环境下.那么,我们就应该记录这些错误,然后改正.这里,我的出错管理页面是在global.a ...

  8. asp&period;net记录错误日志的方法

    1.说明 在调试发布后的asp.net项目时有可能会遇到意想不到的错误,而未能及时的显示.这就需要记录日志来跟踪错误信息,所以写了个简单的记录信息的方法,记录简单的文本信息也可以使用.此方法是以生成文 ...

  9. Asp&period;Net MVC中记录错误日志保存到本地txt文件

    为了方便查询系统出错弄个错误日志出来对于维护运维来说是很有必要的. 1.在Asp.Net MVC项目中的App_Start添加一个用于处理异常类的文件ErrorLog让他继承HandleErrorAt ...

随机推荐

  1. OO之美3

    面向对象和基于对象 基于对象:所以基于对象,就是一种对数据类型的抽象,封装一个结构包含了数据和函数,然后以对象为目标进行操作.构建的基础是对象,但是操作对象并不体现出面向对象的继承性,也就是基于对象局 ...

  2. Apache模块管理

    Apache是一个模块化设计的服务,核心只包含主要功能,扩展功能通过模块实现,不同模块可以被静态的编辑进程序,也可以动态加载. # /usr/local/apache/bin/httpd -M  查看 ...

  3. C&num; 使用ffmpeg&period;exe进行音频转换完整demo

    今天在处理微信的开发接口时候,发现微信多媒体上传接口中返回的音频格式是amr.坑人的是现在大部分的web 播放器,不支持amr的格式播放.试了很多方法都不行. 没办法,只要找一个妥协的解决方案:将am ...

  4. Ext入门学习系列(三)复杂自定义窗体

    通过前2节的学习,基本掌握了Ext的语法和运行原理,可以作出一些简单的应用.本节我们一起来完成复杂点的对话框操作,因为在实际项目中经常要用到确认对话框等多种操作,然后根据客户的选择作出不同的响应. 一 ...

  5. Linux系统在信息社会的发展

    Linux系统在信息社会的发展 随着信息技术的高速发展并迅速渗透到社会生活的各个方面,Linux日益成为人们学习.工作.生活不可缺少的基本工具,再过不了几年,不会使用Linux,就会象不识字一样使人举 ...

  6. 对C&num;中的Close&lpar;&rpar;和Dispose&lpar;&rpar;的浅析

    .net中的许多类都提供了Close()和Dispose()方法,一直以来我都以为它俩是一回事,是完全等价的,在任何地方,用其一即可. 有些类说Close比说Dispose更符合用户的理解(如关闭连接 ...

  7. 强化学习-MDP&lpar;马尔可夫决策过程&rpar;算法原理

    1. 前言 前面的强化学习基础知识介绍了强化学习中的一些基本元素和整体概念.今天讲解强化学习里面最最基础的MDP(马尔可夫决策过程). 2. MDP定义 MDP是当前强化学习理论推导的基石,通过这套框 ...

  8. JMeter 参数化之利用JDBCConnectionConfiguration从数据库读取数据并关联变量

    参数化之利用DBC Connection Configuration从数据库读取数据并关联变量   by:授客 QQ:1033553122 1.   下载mysql jar包 下载mysql jar包 ...

  9. 《JavaWeb程序开发入门》课后题

    第一章 1.请编写一个格式良好的XML文档,要求包含足球队一支,队名为Madrid,球员5人:Ronaldo.Casillas.Ramos.Modric.Benzema:篮球队一支,队名为Lakers ...

  10. django&plus;uwsgi&plus;nginx&plus;sqlite3部署+screen

    note:可通过该命令查找文件未知 sudo find / -name filename 一:项目(github) ssh root@server ip         #  连接你的服务器 git ...