ashx程序里的使用,转载加个人观点

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是三个很苍劲的日志管理库,小编要好也用了下,这里作下记录:

Log4.Net 在Winfrom、MVC、ashx程序里的行使,ashx程序里使用异步

 

  方今做五个双11平移的,是一套相关的H5页面。本来感到难度十分的小,不过做下来几天还是蒙受些难点。就总括一下吧,依旧有获取的。

1.在H5页面中,有一个遮罩层,依旧挺风趣的。直接用div css调节遮罩层页面。

 

图片 1图片 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

 

log4.Net在这里二种分歧的.net程序中增进应用,依然不一样样的,不打听的话,死活就是出不来日志文件。

下边是二种分裂程序配置log4.Net的章程,注意,Winfrom和MVC,ashx的章程各异,也无法混用。

2.log4.net 在Winfrom、MVC、ashx程序里的利用 

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

  ②在App.config中实行log4.net的有关布署。

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

图片 3图片 4

 app.config文件

图片 5图片 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.log4.net 在Winfrom、MVC、ashx程序里的使用

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

    ②在Web.config中张开log4.net的相干铺排。

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

 

  图片 7图片 8

 

 4.log4.net 在Winfrom、MVC、ashx程序里的应用

   ashx那体系型的次序,能够看作mvc程序,他们都以web程序,能发布到IIS上,所以能够把ashx程序在按mvc程序来对待。

     ①在ashx程序中增加log.net的dll的援用。

     ②在Web.config中举办log4.net的相干安插。

  ③因为暗中同意的ashx程序里不曾Global.asax文件,所以要先增加多个Global.asax文件。

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

 

  图片 9

图片 10

 

5.ashx程序里应用异步

  程序里用到了发短信的机能,发短信的代码是写成异步的,即async和await这种主要字。

前面一个调用代码:

图片 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;

                } 
            });

图片 12;)

Reg.ashx代码:

图片 13;)

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

图片 14;)

前台是用ajax异步去调用日常管理程序的,本以为那样能够,可是报错。

图片 15

图片 16

消除措施:利用HttpTaskAsyncHandler那几个接口,替换掉IHttpHandler接口,复写ProcessRequestAsync方法,之后就能够健康访谈。

图片 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);
        }
    }

图片 18;)

 

 

 

 6.ashx程序里应用Session

     ashx程序不能够平昔利用Session,要想行使,必得继承继口System.Web.SessionState.IRequiresSessionState,之后便能健康使用。

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

图片 20;)

 

参考:

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

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

  3.await和async在相似管理程序中的使用

  4.ashx貌似管理程序中的Session读写标题

    5.JS CSS轻松达成DIV遮罩层展现隐蔽

转载自:

图片 21

  

先是新建一个类型Log4NetTest,然后将log4net.dll程序集增多援引至Log4NetTest。

2.随之在档案的次序中增多log4net.config文件,以至手撸或研究二个LogHelper

 

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

增添完log4net.config应当要安装属性,将其一味复制到输出目录

  • 3.加多log4net.config配置文件:

图片 22

图片 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="loglogfile.log"/>
      <appendToFile value="true"/>
      <rollingStyle value="Composite"/>
      <datePattern value="yyyyMMdd"/>
      <maxSizeRollBackups value="10"/>
      <maximumFileSize value="1MB"/>
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="
			

本文由星彩网app下载发布于计算机编程,转载请注明出处:ashx程序里的使用,转载加个人观点

TAG标签: 星彩网app下载
Ctrl+D 将本页面保存为书签,全面了解最新资讯,方便快捷。