<appender type="log4net.Appender.RollingFileAppender">
<!--这个就是我在上面提到的RollingFileAppender-->
<file value="example.log" /><!--文件名称-->
<appendToFile value="false" /><!--会创建新文件,一般设置为true,这里设置为false,是为了看到创建的文件-->
<maximumFileSize value="1KB" /><!--文件大小-->
<maxSizeRollBackups value="20" /><!--创建最大文件数-->
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%level %thread %logger - %message%newline" />
</layout>
</appender>
在log4net节点中还有两个节点
复制代码 代码如下:
<logger>
<level value="Warn"/>
<appender-ref ref="ADONetAppender"/>
</logger>
<root>
<level value="info" />
<!--<appender-ref ref="ADONetAppender" />-->
<appender-ref ref="SmtpAppender"/>
<!--<appender-ref ref="LogFileAppender"/>
<appender-ref ref="ColoredConsoleAppender"/>
<appender-ref ref="EventLogAppender"/>
<append-ref ref="NetSendAppender"/>
<appender-ref ref="RollingFile"/>-->
</root>
在框架的体系里,所有的日志对象都是根日志(root logger)的后代。 因此如果一个日志对象没有在配置文件里显式定义,则框架使用根日志中定义的属性。在<root>标签里,可以定义level级别值和Appender的列表。如果没有定义LEVEL的值,则缺省为DEBUG。可以通过<appender-ref>标签定义日志对象使用的Appender对象。<appender-ref>声明了在其他地方定义的Appender对象的一个引用。在一个logger对象中的设置会覆盖根日志的设置。而对Appender属性来说,子日志对象则会继承父日志对象的Appender列表。这种缺省的行为方式也可以通过显式地设定<logger>标签的additivity属性为false而改变。
那么上面就会有数据库日志的写入和邮箱的写入
在Global.asax文件初始化配置
复制代码 代码如下: