在ASP.NET MVC log4net的:没有任何反应 [英] log4net with ASP.NET MVC: nothing happens
问题描述
我想用ASP.NET MVC使用log4net的,我不能得到任何与它发生。
我创建一个配置就是在我的web项目的根:
<&log4net的GT;
<根和GT;
<电平值=INFO/>
<附加目的地-REF REF =RollingLogFileAppender/>
< /根> <追加程序名称=RollingFileAppender进行TYPE =log4net.Appender.RollingFileAppender>
<文件值=C:\\ DWSApplicationFiles \\ AppLogs \\ app.log/>
< appendToFile值=真/>
< rollingStyle值=大小/>
< maxSizeRollBackups值=10/>
< maximumFileSize值=100KB/>
< staticLogFileName值=真/>
<布局类型=log4net.Layout.PatternLayout>
< conversionPattern值=%D [%T]% - 5P%C [%X] - %M%N/>
< /布局>
< /附加器> <追加程序名称=RollingLogFileAppenderTYPE =log4net.Appender.RollingFileAppender>
<文件值=C:\\ DWSApplicationFiles \\ AppLogs \\ app.log/>
< appendToFile值=FALSE/>
< datePattern值= - DDDD/>
< rollingStyle值=日期/>
<布局类型=log4net.Layout.PatternLayout>
< conversionPattern值=%D [%T]% - 5P%C [%X] - %M%N/>
< /布局>
< /附加器>
< / log4net的>
在问我:是的,应用程序有写权限的目录。我测试了这一点,并应用有权此目录。
下面是我想使用log4net的:
公共类HomeController的:控制器
{
只读log4net.ILog日志= log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod()DeclaringType);
公众的ActionResult指数()
{
log.Error(在索引);
返回查看();
}
}
当我运行应用程序,并转到该控制器log4net的什么也不做;它不创建在该目录或任何文件。
我启用了log4net的内部调试和我在控制台中看到任何输出错误。
下面是我从log4net的看到:
log4net的:log4net的集会[log4net的,版本= 1.2.10.0,文化=中性公钥= 1b44e1d426115821。从加载[C:\\用户\\ twaldron.BULLFROGSPAS \\应用程序数据\\本地\\ TEMP \\临时ASP.NET文件\\ ROOT \\ 7642c99a \\ 60feb7f2 \\装配\\ DL3 \\ 17247033 \\ 008dfd6d_e2d0ca01 \\ log4net.DLL。 (.NET运行库[2.0.50727.4952]在Microsoft Windows NT 6.1.7600.0)
log4net的:DefaultRepositorySelector:defaultRepositoryType [log4net.Repository.Hierarchy.Hierarchy]
log4net的:DefaultRepositorySelector:创建组件库[Bullfrog.DWS.Web,版本= 1.0.0.0,文化=中立,公钥=空]
log4net的:DefaultRepositorySelector:大会[Bullfrog.DWS.Web,版本= 1.0.0.0,文化=中立,公钥=空]加载从[C:\\用户\\ twaldron.BULLFROGSPAS \\应用程序数据\\本地\\ TEMP \\临时ASP。 NET文件\\ ROOT \\ 7642c99a \\ 60feb7f2 \\装配\\ DL3 \\ 2960c79f \\ b876bb2d_aca7cb01 \\ Bullfrog.DWS.Web.DLL]
log4net的:DefaultRepositorySelector:大会[Bullfrog.DWS.Web,版本= 1.0.0.0,文化=中立,公钥=空]中指定的RepositoryAttribute没有
log4net的:DefaultRepositorySelector:大会[Bullfrog.DWS.Web,版本= 1.0.0.0,文化=中立,公钥=空]使用存储库[log4net的默认存储库]和库类型[log4net.Repository.Hierarchy.Hierarchy]
log4net的:DefaultRepositorySelector:创建库[log4net的默认存储库]使用类型[log4net.Repository.Hierarchy.Hierarchy]
WebDev.WebServer20.EXE(管理(V2.0.50727)):已加载匿名运行DynamicMethods大会
块引用>解决方案你有没有在Global.asax中这样的事情?
无效的Application_Start(对象发件人,EventArgs的发送)
{
串l4net =使用Server.Mappath(〜/ log4net.config);
log4net.Config.XmlConfigurator.ConfigureAndWatch(新System.IO.FileInfo(l4net)); ...I am trying to use log4net with ASP.NET MVC and I cannot get anything to happen with it. I've created a config that is in my web project root:
<log4net> <root> <level value="INFO" /> <appender-ref ref="RollingLogFileAppender"/> </root> <appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender"> <file value="C:\DWSApplicationFiles\AppLogs\app.log" /> <appendToFile value="true" /> <rollingStyle value="Size" /> <maxSizeRollBackups value="10" /> <maximumFileSize value="100KB" /> <staticLogFileName value="true" /> <layout type="log4net.Layout.PatternLayout"> <conversionPattern value="%d [%t]%-5p %c [%x] - %m%n" /> </layout> </appender> <appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender"> <file value="C:\DWSApplicationFiles\AppLogs\app.log" /> <appendToFile value="false" /> <datePattern value="-dddd" /> <rollingStyle value="Date" /> <layout type="log4net.Layout.PatternLayout"> <conversionPattern value="%d [%t]%-5p %c [%x] - %m%n" /> </layout> </appender> </log4net>
Before I am asked: yes, the application has permission to write to the directory. I have tested this and the application has permission to this directory.
Here is where I am trying to use log4net:
public class HomeController : Controller { readonly log4net.ILog log = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType); public ActionResult Index() { log.Error("In Index "); return View(); } }
When I run the application and go to this controller log4net does nothing; it doesn't create the files in that directory or anything.
I have enabled internal debugging for log4net and I get no output errors in the console. The following is all I see from log4net:
log4net: log4net assembly [log4net, Version=1.2.10.0, Culture=neutral, PublicKeyToken=1b44e1d426115821]. Loaded from [C:\Users\twaldron.BULLFROGSPAS\AppData\Local\Temp\Temporary ASP.NET Files\root\7642c99a\60feb7f2\assembly\dl3\17247033\008dfd6d_e2d0ca01\log4net.DLL]. (.NET Runtime [2.0.50727.4952] on Microsoft Windows NT 6.1.7600.0)
log4net: DefaultRepositorySelector: defaultRepositoryType [log4net.Repository.Hierarchy.Hierarchy]
log4net: DefaultRepositorySelector: Creating repository for assembly [Bullfrog.DWS.Web, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null]
log4net: DefaultRepositorySelector: Assembly [Bullfrog.DWS.Web, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null] Loaded From [C:\Users\twaldron.BULLFROGSPAS\AppData\Local\Temp\Temporary ASP.NET Files\root\7642c99a\60feb7f2\assembly\dl3\2960c79f\b876bb2d_aca7cb01\Bullfrog.DWS.Web.DLL]
log4net: DefaultRepositorySelector: Assembly [Bullfrog.DWS.Web, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null] does not have a RepositoryAttribute specified.
log4net: DefaultRepositorySelector: Assembly [Bullfrog.DWS.Web, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null] using repository [log4net-default-repository] and repository type [log4net.Repository.Hierarchy.Hierarchy]
log4net: DefaultRepositorySelector: Creating repository [log4net-default-repository] using type [log4net.Repository.Hierarchy.Hierarchy] 'WebDev.WebServer20.EXE' (Managed (v2.0.50727)): Loaded 'Anonymously Hosted DynamicMethods Assembly'
解决方案Do you have something like this in global.asax?
void Application_Start(object sender, EventArgs e) { string l4net = Server.MapPath("~/log4net.config"); log4net.Config.XmlConfigurator.ConfigureAndWatch(new System.IO.FileInfo(l4net)); ...
这篇关于在ASP.NET MVC log4net的:没有任何反应的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!