壹.NuGet包管理器中设置log4net

  • 原稿地址:
  • 安插文件分析地址:
  • 1.引入库log4net.dll

  • 二.开始展览项目文件下的Properties文件夹,打开AssemblyInfo.cs并在AssemblyInfo.cs中添加壹行:在AssemblyInfo.cs中添加一行:(个中log四net.config对应配置文件名)

    [assembly: log4net.Config.XmlConfigurator(ConfigFile = “log4net.config”, ConfigFileExtension = “config”, Watch = true)]

远近闻明log四net是二个很强大的日记管理库,我要好也用了下,那里作下记录:

Log4.Net 在Winfrom、MVC、ashx程序里的应用,ashx程序里选取异步

 

  近期做一个双1一运动的,是1套相关的H伍页面。本来认为难度非常小,然则做下来几天仍然遇到些难点。就计算一下吗,依然有获得的。

壹.在H5页面中,有3个遮罩层,照旧挺有意思的。直接用div+css控制遮罩层页面。

 

金沙注册送58 1金沙注册送58 2

<!DOCTYPE html >
<head>
<title>DIV CSS遮罩层</title>
<script language="javascript" type="text/javascript">
function showdiv() {            
            document.getElementById("bg").style.display ="block";
            document.getElementById("show").style.display ="block";
        }
function hidediv() {
            document.getElementById("bg").style.display ='none';
            document.getElementById("show").style.display ='none';
        }
</script>
<style type="text/css">
        #bg{ display: none;  position: absolute;  top: 0%;  left: 0%;  width: 100%;  height: 100%;  background-color: black;  z-index:1001;  -moz-opacity: 0.7;  opacity:.70;  filter: alpha(opacity=70);}
        #show{display: none;  position: absolute;  top: 25%;  left: 22%;  width: 53%;  height: 49%;  padding: 8px;  border: 8px solid #E8E9F7;  background-color: white;  z-index:1002;  overflow: auto;}
</style>
</head>
<body>
<input id="btnshow" type="button" value="Show" onclick="showdiv();"/>
<div id="bg"></div>
<div id="show">测试
<input id="btnclose" type="button" value="Close" onclick="hidediv();"/>
</div>
</body>
</html>

View Code

 

log四.Net在那三种分化的.net程序中丰硕应用,依然不雷同的,不打听的话,死活正是出不来日志文件。

下边是两种不相同程序配置log肆.Net的主意,注意,Winfrom和MVC,ashx的秘籍各异,也不可能混用。

二.log四.net
在Winfrom、MVC、ashx程序里的利用 

 
①在Winfrom中添加log.net的dll的引用。

 
二在App.config中开始展览log肆.net的有关安插。

  ③在AssemblyInfo.cs中添加[assembly:
log4net.Config.XmlConfigurator(ConfigFileExtension = “config”, Watch =
true)]

金沙注册送58 3金沙注册送58 4

 app.config文件

金沙注册送58 5金沙注册送58 6

<?xml version="1.0" encoding="utf-8" ?>

<configuration>
  <configSections>
    <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, 
            log4net-net-1.0"/>
  </configSections>


  <log4net>
    <root>
      <level value="ALL"/>
      <appender-ref ref="LogFileAppender"/>
    </root>

    <appender name="LogFileAppender" type="log4net.Appender.FileAppender">
      <param name="File" value="my_log-file.txt"/>
      <param name="AppendToFile" value="true"/>
      <layout type="log4net.Layout.PatternLayout">
        <param name="ConversionPattern" value="%d [%t] %-5p %c [%x] &lt;%X{auth}&gt;%n - %m%n"/>
      </layout>
    </appender>
  </log4net>
  <startup>
    <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5" />
  </startup>
</configuration>

View Code

 

3.log肆.net
在Winfrom、MVC、ashx程序里的采用

 1在Mvc程序中添加log.net的dll的引用。

    2在Web.config中进行log四.net的连锁布署。

 
  ③在Global.asax中添加  log4net.Config.XmlConfigurator.ConfigureAndWatch(new
System.IO.FileInfo(Server.MapPath(“Web.config”)));

 

  金沙注册送58 7金沙注册送58 8

 

 四.log肆.net
在Winfrom、MVC、ashx程序里的选拔

 
 ashx那类别型的次序,能够作为mvc程序,他们都以web程序,能宣布到IIS上,所以能够把ashx程序在按mvc程序来对待。

     1在ashx程序中添加log.net的dll的引用。

     贰在Web.config中展开log四.net的连带陈设。

 
叁因为私下认可的ashx程序里从未Global.asax文件,所以要先添加三个Global.asax文件。

log4net使用格局,ashx程序里的运用。   
 ④在Global.asax中添加  log4net.Config.XmlConfigurator.ConfigureAndWatch(new
System.IO.FileInfo(Server.MapPath(“Web.config”)));

 

  金沙注册送58 9

金沙注册送58 10

 

伍.ashx程序里选择异步

  程序里用到了发短信的效应,发短信的代码是写成异步的,即async和await那种首要字。

前端调用代码:

金沙注册送58 11😉

    $.ajax({
                type: 'POST',
                url: 'Reg.ashx',
                data: postDataReg,
                dataType: 'json',
                success: function (data) {
                    $("#shadow").removeClass("shadow");
                    if (data.status == "0")
                    {
                        $("#regsuccess").css('display', 'block');
                        $("#regbgein").css('display', 'none');
                    }
                    else {
                        alert(data.msg);
                    }
                    clickflag = true;

                } 
            });

金沙注册送58 12😉

Reg.ashx代码:

金沙注册送58 13😉

public class GetUserInfoAsync : IHttpHandler
{
        public async void ProcessRequest(HttpContext context)
        {
            context.Response.ContentType = "text/plain";
            var name = await GetUserAsync();
            context.Response.Write(name);
        }
}

金沙注册送58 14😉

前台是用ajax异步去调用一般处理程序的,本以为这么能够,不过报错。

金沙注册送58 15

金沙注册送58 16

消除方法:利用HttpTaskAsyncHandler那几个接口,替换掉IHttpHandler接口,复写ProcessRequestAsync方法,之后就能平常访问。

金沙注册送58 17😉

    /// <summary>
    /// GetUserInfoAsync 的摘要说明
    /// </summary>
    public class GetUserInfoAsync : HttpTaskAsyncHandler
    {
        private async Task<string> GetUserAsync()
        {
            return await Task.Run(() =>
            {
                return "异步handler";
            });
        }public override async Task ProcessRequestAsync(HttpContext context)
        {
            context.Response.ContentType = "text/plain";
            var name = await GetUserAsync();
            context.Response.Write(name);
        }
    }

金沙注册送58 18😉

 

 

 

 6.ashx程序里使用Session

     ashx程序不能够一贯运用Session,要想使用,必须三番五次接口System.Web.SessionState.IRequiresSessionState,之后便能平常使用。

金沙注册送58 19😉

  public class Handler1 : IHttpHandler, System.Web.SessionState.IRequiresSessionState
    {

        public void ProcessRequest(HttpContext context)
        {
            string code = "codeModel";
            context.Session["codemodel"] = code; //设置session
            context.Session.Timeout = 5;    //设置session有效期5分钟

            var codeModel = context.Session["codemodel"]; //获取session
        }

        public bool IsReusable
        {
            get
            {
                return false;
            }
        }
    }

金沙注册送58 20😉

金沙注册送58, 

参考:

  1.在C#代码中接纳Log四Net(一)简单利用Log4Net

  二.asp.net
Web项目中利用Log肆Net进行不当日志记录

  三.await和async在形似处理程序中的使用

  4.ashx一般处理程序中的Session读写标题

  
 伍.JS+CSS简单兑现DIV遮罩层呈现隐藏

转载自:

金沙注册送58 21

  

先是新建3个类型Log肆NetTest,然后将log四net.dll程序集添加引用至Log四NetTest。

二.随着在档次中添加log四net.config文件,以及手撸或探寻3个LogHelper

 

然后在Log四NetTest项目中的Properties ->
AssemblyInfo.cs文件中加上:[assembly:log4net.Config.XmlConfigurator(Watch
= true)],如图:

添加完log四net.config一定要设置属性,将其始终复制到输出目录

  • 三.添加log四net.config布局文件:

金沙注册送58 22

金沙注册送58 23

那句代码也足以添加到名称空间后边,不过那种办法log4net就只局限于该名称空间内可用,其余名称空间要用也要写这句代码,故能够直接加在AssemblyInfo.cs中作用于全数项目。

 

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <configSections>
    <section name="log4net" type="System.Configuration.IgnoreSectionHandler"/>
  </configSections>
  <log4net>
    <appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
      <file value="log\logfile.log"/>
      <appendToFile value="true"/>
      <rollingStyle value="Composite"/>
      <datePattern value="yyyyMMdd"/>
      <maxSizeRollBackups value="10"/>
      <maximumFileSize value="1MB"/>
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline"/>
      </layout>
    </appender>
    <root>
      <level value="All"/>
      <appender-ref ref="RollingLogFileAppender"/>
    </root>
  </log4net>
  <startup>
    <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5"/>
  </startup>
</configuration>

下一场在App.config中写相应的log四net所需的布局消息,写好后就能够在Main函数中用代码:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <configSections>
    <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
  </configSections>
  <log4net xsi:noNamespaceSchemaLocation="http://csharptest.net/downloads/schema/log4net.xsd"
          xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
    <root>
      <level value="DEBUG"/>
      <appender-ref ref="ErrorRollingFileAppender"/>
      <appender-ref ref="WarnRollingFileAppender"/>
      <appender-ref ref="InfoRollingFileAppender"/>
      <appender-ref ref="DebugRollingFileAppender"/>
    </root>

    <!--一般错误日志定义,用于记录已知需处理的与未捕获的异常-->
    <!--日志输出格式:[时间]:类名 线程号 消息-->
    <appender name="ErrorRollingFileAppender" type="log4net.Appender.RollingFileAppender">
      <filter type="log4net.Filter.LevelRangeFilter">
        <levelMin value="ERROR"/>
        <levelMax value="FATAL"/>
      </filter>
      <filter type="log4net.Filter.DenyAllFilter"/>
      <file value="logs\"/>
      <rollingStyle value="Date"/>
      <datePattern value="yyyy-MM-dd\\&quot;Error.log&quot;"/>
      <staticLogFileName value="false"/>
      <lockingModel type="log4net.Appender.FileAppender+MinimalLock"/>
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="[%d{yyyy-MM-dd HH:mm:ss.fff}] %-5p %c.%M %t %n%m%n"/>
      </layout>
    </appender>

    <!--警告日志定义,用于记录已知不需处理的异常,系统警告信息-->
    <!--日志输出格式:[时间]:类名 线程号 消息-->
    <appender name="WarnRollingFileAppender" type="log4net.Appender.RollingFileAppender">
      <filter type="log4net.Filter.LevelMatchFilter">
        <levelToMatch value="WARN"/>
      </filter>
      <filter type="log4net.Filter.DenyAllFilter"/>
      <file value="logs\"/>
      <appendToFile value="true"/>
      <rollingStyle value="Date"/>
      <datePattern value="yyyy-MM-dd\\&quot;Warn.log&quot;"/>
      <staticLogFileName value="false"/>
      <lockingModel type="log4net.Appender.FileAppender+MinimalLock"/>
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="[%d{yyyy-MM-dd HH:mm:ss.fff}] %c.%M %t %m%n"/>
      </layout>
    </appender>

    <!--信息日志定义,用于记录用户相关信息-->
    <!--日志输出格式:[时间]:消息-->
    <appender name="InfoRollingFileAppender" type="log4net.Appender.RollingFileAppender">
      <filter type="log4net.Filter.LevelMatchFilter">
        <levelToMatch value="INFO"/>
      </filter>
      <filter type="log4net.Filter.DenyAllFilter"/>
      <file value="logs\"/>
      <appendToFile value="true"/>
      <rollingStyle value="Date"/>
      <datePattern value="yyyy-MM-dd\\&quot;Info.log&quot;"/>
      <staticLogFileName value="false"/>
      <lockingModel type="log4net.Appender.FileAppender+MinimalLock"/>
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="[%d{yyyy-MM-dd HH:mm:ss}] %m%n"/>
      </layout>
    </appender>

    <!--信息日志定义,用于收集开发调试信息-->
    <!--日志输出格式:[时间]:类名 线程号 消息-->
    <appender name="DebugRollingFileAppender" type="log4net.Appender.RollingFileAppender">
      <filter type="log4net.Filter.LevelMatchFilter">
        <levelToMatch value="DEBUG"/>
      </filter>
      <filter type="log4net.Filter.DenyAllFilter"/>
      <file value="logs\"/>
      <appendToFile value="true"/>
      <rollingStyle value="Date"/>
      <datePattern value="yyyy-MM-dd\\&quot;Debug.log&quot;"/>
      <staticLogFileName value="false"/>
      <lockingModel type="log4net.Appender.FileAppender+MinimalLock"/>
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="[%d{yyyy-MM-dd HH:mm:ss.fff}] %c %t:%m%n"/>
      </layout>
    </appender>

  </log4net>
</configuration>

  

ILog log = LogManager.GetLogger(typeof (Program));  // typeof(Program)的作用貌似是与 引用当前程序集有关。
            log.Error("ErrMsg", new Exception("Error异常。"));
            log.Fatal("FatalMsg", new Exception("Fatal异常。"));
            log.Info("InfoMsg", new Exception("Info信息。"));
            log.Debug("DebugMsg", new Exception("Debug信息。"));
            log.Warn("WarnMsg", new Exception("我怎么"));
            Console.WriteLine("Log It's Ok");
            Console.ReadKey();

 

 

假若想将log四net的安插写在2个单身的.config文件中,如log4net.config,则要求

 1     public static class LogHelper
 2     {
 3         private static readonly log4net.ILog Logerror = log4net.LogManager.GetLogger("DEBUG");
 4 
 5         public static void WriteInfoLog(string info)
 6         {
 7             Logerror.Info(info);
 8         }
 9 
10         public static void WriteErrorLog(string info)
11         {
12             Logerror.Error(info);
13         }
14 
15         public static void WriteDebugLog(string info)
16         {
17             Logerror.Debug(info);
18         }
19 
20         public static void WriteDebugLog(Exception exception)
21         {
22             Logerror.Debug(exception.Message, exception);
23         }
24     }
  • 肆.添加三个公共的日记管理类AppLog.cs

    using System;
    using System.Collections.Generic;
    using System.Text;
    using log4net;
    using log4net.Config;
    using System.IO;

修改[assembly:log4net.Config.XmlConfigurator(Watch =
true)]为:[assembly: log4net.Config.XmlConfigurator(ConfigFile = ``"log4net.config"``, Watch = ``true``)]。

 三.最终索要在AssemblyInfo.cs中添加一行代码

namespace log4net
{
    /// <summary>
    /// 使用Log4net插件的log日志对象
    /// </summary>
    public static class AppLog
    {
        private static ILog log;

        static AppLog()
        {
            XmlConfigurator.ConfigureAndWatch(new FileInfo(AppDomain.CurrentDomain.SetupInformation.ConfigurationFile));
            log = LogManager.GetLogger(typeof(AppLog));
        }

        public static void Debug(object message)
        {
            log.Debug(message);
        }

        public static void DebugFormatted(string format, params object[] args)
        {
            log.DebugFormat(format, args);
        }

        public static void Info(object message)
        {
            log.Info(message);
        }

        public static void InfoFormatted(string format, params object[] args)
        {
            log.InfoFormat(format, args);
        }

        public static void Warn(object message)
        {
            log.Warn(message);
        }

        public static void Warn(object message, Exception exception)
        {
            log.Warn(message, exception);
        }

        public static void WarnFormatted(string format, params object[] args)
        {
            log.WarnFormat(format, args);
        }

        public static void Error(object message)
        {
            log.Error(message);
        }

        public static void Error(object message, Exception exception)
        {
            log.Error(message, exception);
        }

        public static void ErrorFormatted(string format, params object[] args)
        {
            log.ErrorFormat(format, args);
        }

        public static void Fatal(object message)
        {
            log.Fatal(message);
        }

        public static void Fatal(object message, Exception exception)
        {
            log.Fatal(message, exception);
        }

        public static void FatalFormatted(string format, params object[] args)
        {
            log.FatalFormat(format, args);
        }
    }
}

且要将log四net.config文件设置为复制到输出目录。(推荐将log四net的配置写在独立的配备文件中)

 金沙注册送58 24

  • 伍.在别的你想写日记的地点采用,例如:

    AppLog.Info(“Info log”);
    AppLog.Error(“Error log”);

log肆net.config中的配置音信可为:

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

  

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
    <configSections>
        <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net"/>
    </configSections>

    <log4net>

        <root>
            <level value="ALL" />
            <appender-ref ref="InfoAppender" />
            <appender-ref ref="WarnAppender" />
            <appender-ref ref="ErrorAppender" />
            <appender-ref ref="FatalAppender" />
            <appender-ref ref="DebugAppender" />
        </root>

        <!-- 输出模式定义 -->
        <appender name="InfoAppender" type="log4net.Appender.RollingFileAppender">
            <!--日志路径: 兼容相对路径和绝对路径,此语句等价于<File value="Logs\"/> -->
            <param name= "File" value= "Logs\"/>
            <!--是否是向文件中追加日志-->
            <param name= "AppendToFile" value= "true"/>
            <!--保留天数-->
            <param name= "MaxSizeRollBackups" value= "-1"/>
            <!--日志文件名是否固定不变的-->
            <param name= "StaticLogFileName" value= "false"/>
            <!--日志文件名格式为:2017-01-12_Info.log-->
            <param name= "DatePattern" value= "yyyy-MM-dd&quot;_Info.log&quot;"/>
            <!--日志根据日期滚动-->
            <param name= "RollingStyle" value= "Date"/>
       <!-- 每条记录的头和尾 -->
       <header value="{*" />
       <footer value="*}" /> 
            <!-- 写入记录文件时的格式%p应该指模式如WARN,%m应该指Message值,%n应该是换行的意思。接着输出Exception -->
            <layout type="log4net.Layout.PatternLayout">
                <param name="ConversionPattern" value="%date{yyyy-MM-dd HH:mm:ss.fff} %-8p %m%n" />
            </layout>
            <!-- 此模式输出的级别范围 -->
       <!-- FATAL > ERROR > WARN > INFO > DEBUG --> 
            <filter type="log4net.Filter.LevelRangeFilter">
                <levelMin value="INFO" />
                <levelMax value="INFO" />
            </filter>
        </appender>

        <appender name="WarnAppender" type="log4net.Appender.RollingFileAppender">
            <File value= "Logs\"/>
            <param name= "AppendToFile" value= "true"/>
            <param name= "MaxSizeRollBackups" value= "10"/>
            <!-- 能保存的文件最大值,假设某次输出后该文件如mm_warn.log的大小将会超过最大值3KB,则此次输出仍有效,但是下次输出则会将该文件重命名为mm_warn.log.1,且生成一个新的mm_warn.log文件以供记录输出内容。 -->
            <param name="MaximumFileSize" value="3KB" />
            <param name= "StaticLogFileName" value= "false"/>
            <param name= "DatePattern" value= "yyyy-MM-dd&quot;_Warn.log&quot;"/>
            <param name= "RollingStyle" value= "Composite"/>
            <!-- 写入记录文件时的格式 -->
            <layout type="log4net.Layout.PatternLayout">
                <param name="ConversionPattern" value="%date{yyyy-MM-dd HH:mm:ss.fff} %-8p %m%n" />
            </layout>
            <!-- 此模式输出的级别范围 -->
            <filter type="log4net.Filter.LevelRangeFilter">
                <levelMin value="WARN" />
                <levelMax value="WARN" />
            </filter>
        </appender>

        <appender name="ErrorAppender" type="log4net.Appender.RollingFileAppender">
            <param name= "File" value= "Logs\"/>
            <param name= "AppendToFile" value= "true"/>
            <param name= "MaxSizeRollBackups" value= "10"/>
            <!-- 能保存的文件最大值 -->
            <param name="MaximumFileSize" value="1MB" />
            <param name= "StaticLogFileName" value= "false"/>
            <param name= "DatePattern" value= "yyyy-MM-dd&quot;_Error.log&quot;"/>
            <param name= "RollingStyle" value= "Date"/>
            <layout type="log4net.Layout.PatternLayout">
                <param name="ConversionPattern" value="%date{yyyy-MM-dd HH:mm:ss.fff} %-8p %m%n" />
            </layout>
            <!-- 此模式输出的级别范围 -->
            <filter type="log4net.Filter.LevelRangeFilter">
                <levelMin value="ERROR" />
                <levelMax value="ERROR" />
            </filter>
        </appender>

        <appender name="FatalAppender" type="log4net.Appender.RollingFileAppender">
            <param name= "File" value= "Logs\"/>
            <param name= "AppendToFile" value= "true"/>
            <param name= "MaxSizeRollBackups" value= "10"/>
            <param name= "StaticLogFileName" value= "false"/>
            <param name= "DatePattern" value= "yyyy-MM-dd&quot;_Fatal.log&quot;"/>
            <param name= "RollingStyle" value= "Date"/>
            <layout type="log4net.Layout.PatternLayout">
                <param name="ConversionPattern" value="%date{yyyy-MM-dd HH:mm:ss.fff} %-8p %m%n" />
            </layout>
            <!-- 此模式输出的级别范围 -->
            <filter type="log4net.Filter.LevelRangeFilter">
                <levelMin value="FATAL" />
                <levelMax value="FATAL" />
            </filter>
        </appender>

        <appender name="DebugAppender" type="log4net.Appender.RollingFileAppender">
            <param name= "File" value= "Logs\"/>
            <param name= "AppendToFile" value= "true"/>
            <param name= "MaxSizeRollBackups" value= "10"/>
            <param name= "StaticLogFileName" value= "false"/>
            <param name= "DatePattern" value= "yyyy-MM-dd&quot;_Debug.log&quot;"/>
            <param name= "RollingStyle" value= "Date"/>
            <layout type="log4net.Layout.PatternLayout">
                <param name="ConversionPattern" value="%date{yyyy-MM-dd HH:mm:ss.fff} %-8p %m%n" />
            </layout>
            <!-- 此模式输出的级别范围 -->
            <filter type="log4net.Filter.LevelRangeFilter">
                <levelMin value="DEBUG" />
                <levelMax value="DEBUG" />
            </filter>
        </appender>

    </log4net>
</configuration>

作用如下:


 

1         static void Main(string[] args)
2         {
3             LogHelper.WriteDebugLog("1234444445");
4         }
  • 陆.经验之谈:不要把项目名称起为log四net,或任何数字在中等的称号,不然引入log四net.dll的时候就会一向报错
  • **七.当运营平常未有开创日志文件只怕log =
    LogManager.GetLogger(typeof(AppLog))中log对象字段值为false时,右击log四net.config选用属性**–>高级把复制到项目的值改为始终复制**
  •  八  类库项目中就如不能够落到实处此打字与印刷日志功效,

金沙注册送58 25

 

Demo下载:

 

相关文章

网站地图xml地图