ashx程序里采用异步,程序中用log4net

1.NuGet包管理器中设置log4net

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

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

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

远近驰名log4net是三个很强劲的日记管理库,笔者自身也用了下,那里作下记录:

 

美高梅开户网址 1

  

首先新建三个连串Log4NetTest,然后将log4net.dll程序集添加引用至Log4NetTest。

  近日做一个双11活动的,是一套相关的H5页面。本来觉得难度非常的小,可是做下来几天也许碰到些难点。就总括一下呢,依然有获取的。

2.随着在类型中添加log4net.config文件,以及手撸或探寻1个LogHelper

 

接下来在Log4NetTest项目中的Properties ->
AssemblyInfo.cs文件中拉长:[assembly:log4net.Config.XmlConfigurator(Watch
= true)],如图:

1.在H5页面中,有三个遮罩层,依然挺好玩的。直接用div+css控制遮罩层页面。

添加完log4net.config一定要设置属性,将其一直复制到输出目录

  • 3.添加log4net.config布署文件:

美高梅开户网址 2

ashx程序里采用异步,程序中用log4net。 

美高梅开户网址 3

那句代码也可以拉长到名称空间后面,但是那种艺术log4net就只局限于该名称空间内可用,其余名称空间要用也要写那句代码,故能够直接加在AssemblyInfo.cs中效果于全体项目。

美高梅开户网址 4美高梅开户网址 5

 

<?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中写相应的log4net所需的安插消息,写好后就能够在Main函数中用代码:

<!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>
<?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();

View Code

 

 

一旦想将log4net的配置写在一个独自的.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     }
  • 4.添加1个国有的日记管理类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``)]。

log4.Net在那三种区别的.net程序中丰盛应用,依旧不雷同的,不打听的话,死活正是出不来日志文件。

 3.最终索要在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);
        }
    }
}

且要将log4net.config文件设置为复制到输出目录。(推荐将log4net的布局写在独立的安顿文件中)

上面是三种差别程序配置log4.Net的法子,注意,Winform和MVC,ashx的办法差别,也不可能混用。

 美高梅开户网址 6

  • 5.在其余你想写日记的地点使用,例如:

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

log4net.config中的配置音信可为:

2.log4.net
在Winform、MVC、ashx程序里的选取 

[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>

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

功效如下:


 

 
②在App.config中进行log4.net的连带配置。

1         static void Main(string[] args)
2         {
3             LogHelper.WriteDebugLog("1234444445");
4         }
  • 6.经历之谈:不要把项目名称起为log4net,或任何数字在在这之中的称谓,不然引入log4net.dll的时候就会直接报错
  • **7.当运维符合规律化没有创建日志文件恐怕log =
    LogManager.GetLogger(typeof(AppLog))中log对象字段值为false时,右击log4net.config接纳属性**–>高级把复制到项指标值改为始终复制**
  •  8  类库项目中接近无法兑现此打字与印刷日志成效,

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

美高梅开户网址 7

美高梅开户网址 8美高梅开户网址 9

 

 app.config文件

Demo下载:

美高梅开户网址 10美高梅开户网址 11

 

<?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.log4.net
在Winform、MVC、ashx程序里的使用

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

    ②在Web.config中进行log4.net的连锁计划。

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

 

  美高梅开户网址 12美高梅开户网址 13

 

 4.log4.net
在Winform、MVC、ashx程序里的使用

 
 ashx那体系型的顺序,能够看成mvc程序,他们都以web程序,能发表到IIS上,所以能够把ashx程序在按mvc程序来比较。

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

     ②在Web.config中展开log4.net的连带布置。

 
③因为暗许的ashx程序里从未Global.asax文件,所以要先添加3个Global.asax文件。

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

美高梅开户网址 , 

  美高梅开户网址 14

美高梅开户网址 15

 

5.ashx顺序里采取异步

  程序里用到了发短信的职能,发短信的代码是写成异步的,即async和await那种重庆大学字。

前者调用代码:

    $.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;

                } 
            });

Reg.ashx代码:

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

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

美高梅开户网址 16

美高梅开户网址 17

解决措施:利用HttpTaskAsyncHandler那个接口,替换掉IHttpHandler接口,复写ProcessRequestAsync方法,之后就能健康访问。

    /// <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);
        }
    }

 

 

 

 6.ashx程序里应用Session

     ashx程序不可能向来利用Session,要想利用,必须三番五次接口System.Web.SessionState.IRequiresSessionState,之后便能符合规律使用。

  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;
            }
        }
    }

 

参考:

  1.在C#代码中应用Log4Net(一)简单利用Log4Net

  2.asp.net
Web项目中运用Log4Net实行不当日志记录

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

  4.ashx相似处理程序中的Session读写标题

  
 5.JS+CSS不难贯彻DIV遮罩层突显隐藏

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图