首页  ·  知识 ·  云计算
net捕获全局异常并且记录日志、多线程方式发送邮件提醒
网友    综合  编辑:dezai   图片来源:网络
net捕获全局异常并且记录日志、多线程方式发送邮件提醒
 在软件、网站中难免会出现种种异常,如果你的项目中有未处理的异常并且不想一处处的加异常那么可以借鉴下一下这个方案

1.新建一个全局应用文件Global.asax此文件在统计在线人数的时候应用较多

2.此文件中有个Application_Error方法此方案就是用的这个方法,加入以下捕获异常的代码

 

//在出现未处理的错误时运行的代码

         Exception ex = Server.GetLastError();

         StringBuilder sb = new StringBuilder();

         string dt = DateTime.Now.ToString();

         sb.Append("------\r\n").Append(dt).Append("\r\n内部错误:").Append(ex.InnerException.ToString())

             .Append("\r\n堆栈:").Append(ex.StackTrace).Append("\r\n内容:").Append(ex.Message)

             .Append("\r\n来源:").Append(ex.Source).Append("\r\n");

         Log.SetLog(sb.ToString());

         Server.ClearError();

         Server.Transfer("error.aspx", false);

新建个记录日志并且自动发送邮件提醒的类

using System;

 using System.Collections.Generic;

 using System.Linq;

 using System.Web;

 using System.IO;

 using System.Threading;

 /// <summary>

 ///Log 的摘要说明

 /// </summary>

 public class Log

 {

     public Log()

     {

         //

 //TODO: 在此处添加构造函数逻辑

 //

     }

     private string logBody;

     public string LogBody

     {

         get { return logBody; }

         set { logBody = value; }

     }

     public static void SetLog(string str)

     {

         string path = HttpContext.Current.Server.MapPath("log.log");

         File.AppendAllText(path, str);

         //Thread.Sleep(1000);

         Log log1 = new Log();

         log1.LogBody = str;

         Thread t = new Thread(new ThreadStart(log1.SendEmail));

         t.IsBackground = true;

         t.Start();

     }

 

     private void SendEmail()

     {

         System.Net.Mail.SmtpClient client = new System.Net.Mail.SmtpClient();

         client.Host = "---";

         client.UseDefaultCredentials = false;

         client.Credentials = new System.Net.NetworkCredential("---", "---");

         client.DeliveryMethod = System.Net.Mail.SmtpDeliveryMethod.Network;

         client.Timeout = 9000;

         System.Net.Mail.MailMessage message = new System.Net.Mail.MailMessage("---", "---");

         message.Subject = "---";

         message.Body = logBody;

         message.BodyEncoding = System.Text.Encoding.UTF8;

         message.IsBodyHtml = true;

 

         try

         {

             client.Send(message);

 

         }

         catch(Exception ex)

         {

         }

     }

 }

其中---按需求自行填写

4.新建个error.aspx文件用于捕获异常后转向的提示页面

本文作者:网友 来源:网络
CIO之家 www.ciozj.com 微信公众号:imciow
   
免责声明:本站转载此文章旨在分享信息,不代表对其内容的完全认同。文章来源已尽可能注明,若涉及版权问题,请及时与我们联系,我们将积极配合处理。同时,我们无法对文章内容的真实性、准确性及完整性进行完全保证,对于因文章内容而产生的任何后果,本账号不承担法律责任。转载仅出于传播目的,读者应自行对内容进行核实与判断。请谨慎参考文章信息,一切责任由读者自行承担。
延伸阅读