2011-04-19 165 views
1

在我的项目中我使用MVC,NHibernate和记录html错误我想使用log4net库。log4net日志文件没有创建

这里是web.config配置

<configuration> 
<configSections> 
<section name="hibernate-configuration" type="NHibernate.Cfg.ConfigurationSectionHandler, NHibernate"/> 
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" /> 
<!--<sectionGroup name="blowery.web"> 
     <section name="httpCompress" type="blowery.Web.HttpCompress.SectionHandler, blowery.Web.HttpCompress"/> 
    </sectionGroup>--> 
</configSections> 
<log4net debug="false"> 

<!-- Define some output appenders --> 
<appender name="trace" type="log4net.Appender.TraceAppender, log4net"> 
    <layout type="log4net.Layout.PatternLayout,log4net"> 
    <param name="ConversionPattern" value="%d [%t] %-5p %c - %m%n" /> 
    </layout> 
</appender> 

<appender name="console" type="log4net.Appender.ConsoleAppender, log4net"> 
    <layout type="log4net.Layout.PatternLayout,log4net"> 
    <param name="ConversionPattern" value="%d [%t] %-5p %c - %m%n" /> 
    </layout> 
</appender> 

<appender name="rollingFile" type="log4net.Appender.RollingFileAppender,log4net" > 

    <param name="File" value="log.txt" /> 
    <param name="AppendToFile" value="true" /> 
    <param name="RollingStyle" value="Date" /> 
    <param name="DatePattern" value="yyyy.MM.dd" /> 
    <param name="StaticLogFileName" value="true" /> 

    <layout type="log4net.Layout.PatternLayout,log4net"> 
    <param name="ConversionPattern" value="%d [%t] %-5p %c - %m%n" /> 
    </layout> 
</appender> 

<!-- Setup the root category, add the appenders and set the default priority --> 

<root> 
    <priority value="INFO" /> 
    <appender-ref ref="console" /> 
</root> 
</log4net> 

<hibernate-configuration xmlns="urn:nhibernate-configuration-2.2"> 
<session-factory> 
    <property name="dialect">NHibernate.Dialect.MsSql2005Dialect</property> 
    <property name="connection.provider">NHibernate.Connection.DriverConnectionProvider</property> 

    <property name="connection.connection_string">Password=maserver.login12345;Persist Security Info=True;User ID=sa;Initial Catalog=Mashhad4;Data Source=DEVSERVER</property> 


    <property name="show_sql">true</property> 
    <property name="proxyfactory.factory_class">NHibernate.ByteCode.Castle.ProxyFactoryFactory, NHibernate.ByteCode.Castle</property> 
    <!--<property name="hibernate.batch_size">20</property>--> 

    <!--<property name="command_timeout">5000</property>--> 
</session-factory> 
</hibernate-configuration> 
<configuration> 

在AssemblyInfo.cs文件中我有这样的:

[assembly: log4net.Config.XmlConfigurator(ConfigFile = "Web.config", Watch = true)] 

但在控制器,当我使用这部分代码,它不会产生任何txt文件。

log4net.Config.BasicConfigurator.Configure(); 
     Exception inner = filterContext.Exception.InnerException; 
     log4net.ILog log = log4net.LogManager.GetLogger("MainLogger"); 
     log.Error("Unhandled exception", inner == null ? filterContext.Exception : inner); 

什么问题?根元素下

回答

0

尝试增加此:

<logger name="NHibernate.SQL"> 
    <appender-ref ref="rollingFile" /> 
    <level value="ALL" /> 
</logger> 

编辑:

为了使用称为MainLogger记录器,使用:

<logger name="MainLogger"> 
    <appender-ref ref="rollingFile" /> 
    <level value="ALL" /> 
</logger> 

当在调试模式下,该文件将在<projectfolder>\bin\Debug中创建,因为您没有指定路径而只指定文件名。

+0

我没有工作,没有任何改变 – Adrakadabra 2011-04-19 10:39:20

+0

@Adrakadabra我在我的答案中提出了另一种解决方案。 – 2011-04-19 12:22:48

+0

还确保运行您的Web应用程序(网络服务/本地服务或其他)的用户对您要写入的文件夹具有写入权限 – 2011-04-19 20:28:15