在ASP.NET MVC log4net的:没有任何反应 [英] log4net with ASP.NET MVC: nothing happens

查看:248
本文介绍了在ASP.NET MVC log4net的:没有任何反应的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我想用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屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆