Log4Net 在ASP.NET WebForm 和 MVC的全局配置
使用log4net可以很方便地为应用添加日志功能。应用Log4net,开发者可以很精确地控制日志信息的输出,减少了多余信息,提高了日志记录性能。同时,通过外部配置文件,用户可以不用重新编译程序就能改变应用的日志行为,使得用户可以根据情况灵活地选择要记录的信息。
那么我们如何在Web项目中使用Log4Net呢?
配置方面请点击链接跳转上一笔记:
ASP.NET的错误处理机制之二(实例log4net)
这次主要针对上次的错误机制讲解如何进行Log4Net 在ASP.NET WebForm 和 MVC的全局配置
一、MVC中的全局配置
在项目中添加一个全局应用程序类Global.asax,如下图所示:
方法中添加如下代码:
- protected void Application_Start(object sender, EventArgs e)
- {
- #region 应用程序启动时,自动加载配置log4Net
- XmlConfigurator.Configure();
- #endregion
- }
protected void Application_Error(object sender, EventArgs e)
{
#region 捕获全局异常Exception error = Server.GetLastError().GetBaseException();
Exception ex = Server.GetLastError().GetBaseException();
string ip = Request.ServerVariables.Get("HTTP_X_FORWARDED_FOR") == null ?
Request.ServerVariables.Get("Remote_Addr").ToString().Trim() :
Request.ServerVariables.Get("HTTP_X_FORWARDED_FOR").ToString().Trim();
string logpath = Server.MapPath("~/Log/" + DateTime.Now.ToString("yyyy-MM-dd") + ".txt");
StringBuilder builder = new StringBuilder();
builder.AppendLine(string.Format("========== {0} Application_Error BEGIN ==========", DateTime.Now));
builder.AppendLine("Ip:" + ip);
builder.AppendLine("浏览器:" + Request.Browser.Browser.ToString());
builder.AppendLine("浏览器版本:" + Request.Browser.MajorVersion.ToString());
builder.AppendLine("操作系统:" + Request.Browser.Platform.ToString());
builder.AppendLine("页面:" + Request.Url.ToString());
builder.AppendLine("错误信息:" + ex.Message);
builder.AppendLine("错误源:" + ex.Source);
builder.AppendLine("异常方法:" + ex.TargetSite);
builder.AppendLine("堆栈信息:" + ex.StackTrace);
builder.AppendLine("========== Application_Error END ===================");lock (logpath)
{
try
{
using (var writer = new StreamWriter(logpath, true))
{
ZX.B2C.GoodBaby.Common.LogHelper.WriteLog(typeof(RequestNotification), builder.ToString());
}
}
catch
{
// 防止写文件时,文件被人为打开无法写入等
// 记录日志报错不做处理,不应影响用户继续使用
}
}Server.ClearError();
Response.Redirect("/Error/ErrorPath404");//跳出至404页面#endregion
}
二、WebForm中的全局配置
在项目中添加一个全局应用程序类Global.asax,如下图所示:
方法中添加如下代码:
protected void Application_Start(object sender, EventArgs e)
{
#region 应用程序启动时,自动加载配置log4NetXmlConfigurator.Configure();
#endregion
}
/// <summary>
/// 捕获全局异常
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>protected void Application_Error(object sender, EventArgs e)
{
#region 捕获全局异常Exception error = Server.GetLastError().GetBaseException();
Exception ex = Server.GetLastError().GetBaseException();
string ip = Request.ServerVariables.Get("HTTP_X_FORWARDED_FOR") == null ?
Request.ServerVariables.Get("Remote_Addr").ToString().Trim() :
Request.ServerVariables.Get("HTTP_X_FORWARDED_FOR").ToString().Trim();
string logpath = Server.MapPath("~/Log/" + DateTime.Now.ToString("yyyy-MM-dd") + ".txt");
StringBuilder builder = new StringBuilder();
builder.AppendLine(string.Format("========== {0} Application_Error BEGIN ==========", DateTime.Now));
builder.AppendLine("Ip:" + ip);
builder.AppendLine("浏览器:" + Request.Browser.Browser.ToString());
builder.AppendLine("浏览器版本:" + Request.Browser.MajorVersion.ToString());
builder.AppendLine("操作系统:" + Request.Browser.Platform.ToString());
builder.AppendLine("页面:" + Request.Url.ToString());
builder.AppendLine("错误信息:" + ex.Message);
builder.AppendLine("错误源:" + ex.Source);
builder.AppendLine("异常方法:" + ex.TargetSite);
builder.AppendLine("堆栈信息:" + ex.StackTrace);
builder.AppendLine("========== Application_Error END ===================");lock (logpath)
{
try
{
using (var writer = new StreamWriter(logpath, true))
{
ZX.B2C.GoodBaby.Common.LogHelper.WriteLog(typeof(RequestNotification), builder.ToString());
}
}
catch
{
// 防止写文件时,文件被人为打开无法写入等
// 记录日志报错不做处理,不应影响用户继续使用
}
}Server.ClearError();
Response.Redirect("~/Error.htm");#endregion
}
原文链接:
Log4Net 在ASP.NET WebForm 和 MVC的全局配置
Log4Net 在ASP.NET WebForm 和 MVC的全局配置的更多相关文章
- 解析ASP.NET WebForm和Mvc开发的区别
因为以前主要是做WebFrom开发,对MVC开发并没有太深入的了解.自从来到创新工场的新团队后,用的技术都是自己以前没有接触过的,比如:MVC 和EF还有就是WCF,压力一直很大.在很多问题都是不清楚 ...
- 解析ASP.NET WebForm和Mvc开发的区别 分类: ASP.NET 2013-12-29 01:59 11738人阅读 评论(5) 收藏
因为以前主要是做WebFrom开发,对MVC开发并没有太深入的了解.自从来到创新工场的新团队后,用的技术都是自己以前没有接触过的,比如:MVC 和EF还有就是WCF,压力一直很大.在很多问题都是不清楚 ...
- asp.net core 3.0 MVC JSON 全局配置
asp.net core 3.0 MVC JSON 全局配置 System.Text.Json(default) startup配置代码如下: using System.Text.Encodings. ...
- ASP.NET中HttpApplication中ProcessRequest方法中运行的事件顺序;ASP.NET WebForm和MVC总体请求流程图
ASP.NET中HttpApplication中ProcessRequest方法中运行的事件顺序 1.BeginRequest 開始处理请求 2.AuthenticateRequest 授权验证请求 ...
- [转]asp.net webform 与mvc 共享session
公司内部系统最早是用.net webform模式开发的,现新项目用.net mvc 开发,现存在的问题就是如何保持原有.net webform的登录状态不变,而在mvc中能够验证用户的登录状态,也就是 ...
- asp.net webform 与mvc 共享session
公司内部系统最早是用.net webform模式开发的,现新项目用.net mvc 开发,现存在的问题就是如何保持原有.net webform的登录状态不变,而在mvc中能够验证用户的登录状态,也就是 ...
- [转]解析ASP.NET WebForm和Mvc开发的区别
因为以前主要是做WebFrom开发,对MVC开发并没有太深入的了解.自从来到创新工场的新团队后,用的技术都是自己以前没有接触过的,比如:MVC 和EF还有就是WCF,压力一直很大.在很多问题都是不清楚 ...
- Asp.Net WebForm和MVC同样优秀!
不是说MVC不好,而是WebForm并没有那么不堪,和Mvc同样优秀.对说WebForm缺点多的,表示不服,求指教,虽然本人有些见解可能比较浅薄. 看过很多文章和书籍,都会拿MVC模式和WebForm ...
- ASP.NET WebForm与MVC优缺点
发表于我的个人网站中,请点击阅读!
随机推荐
- Lua基础---lua字符串库函数详解,实例及正则表达式
参考这个网友写的,比较简单容易理解. http://blog.csdn.net/wlgy123/article/details/49206183
- 使用BloomFilter布隆过滤器解决缓存击穿、垃圾邮件识别、集合判重
Bloom Filter是一个占用空间很小.效率很高的随机数据结构,它由一个bit数组和一组Hash算法构成.可用于判断一个元素是否在一个集合中,查询效率很高(1-N,最优能逼近于1). 在很多场景下 ...
- js 下获取子元素的方法
笔记核心: firstElementChild只会获取元素节点对象,从名称就可以看出来,firstChild则可以获取文本节点对象(当然也可以获取元素节点对象),比如空格和换行都被当做文本节点. js ...
- Python 多版本共存之pyenv
经常遇到这样的情况: 系统自带的 Python 是 2.6,自己需要 Python 2.7 中的某些特性: 系统自带的 Python 是 2.x,自己需要 Python 3.x: 此时需要在系统中安装 ...
- BZOJ5340: [Ctsc2018]假面
BZOJ5340: [Ctsc2018]假面 https://lydsy.com/JudgeOnline/problem.php?id=5340 分析: 背包,只需要求\(g_{i,j}\)表示强制活 ...
- php时间 显示刚刚 几分钟前等
功能示例: $now = time();foreach($sys_res as $k => $v){ $day = intval(floor(($now - $v->system_time ...
- Fiddler2 模拟文件上传
最近遇到一个需求,需要上传音频文件, 服务端使用webService 通过spring3 进行文件上传.代码完成后使用 html 通过post 方式请求接口成功了,但不知道如何使用Fiddler2工具 ...
- PTA 是否同一棵二叉搜索树(25 分)
是否同一棵二叉搜索树(25 分) 给定一个插入序列就可以唯一确定一棵二叉搜索树.然而,一棵给定的二叉搜索树却可以由多种不同的插入序列得到.例如分别按照序列{2, 1, 3}和{2, 3, 1}插入初始 ...
- AngularJS:template2
ylbtech-AngularJS: 1.返回顶部 1. 2. 2.返回顶部 3.返回顶部 4.返回顶部 5.返回顶部 1. 2. 6.返回顶部 作者:ylbtech出处:h ...
- 小程序WXML基本使用
数据绑定 <!--wxml--> <view> {{message}} </view> // page.js Page({ data: { message: 'He ...