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

2021-04-30 21:27

阅读:663

YPE html>

 

  最近做一个双11活动的,是一套相关的H5页面。本来以为难度不大,但是做下来几天还是遇到些问题。就总结一下吧,还是有收获的。

1.在H5页面中,有一个遮罩层,还是挺有意思的。直接用div+css控制遮罩层页面。

 

技术分享技术分享
DIV CSS遮罩层
测试
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)]

技术分享技术分享

 app.config文件

技术分享技术分享
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] <%X{auth}>%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")));

 

  技术分享技术分享

 

 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")));

 

  技术分享

技术分享

 

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异步去调用一般处理程序的,本以为这样可以,但是报错。

技术分享

技术分享

解决方法:利用HttpTaskAsyncHandler这个接口,替换掉IHttpHandler接口,复写ProcessRequestAsync方法,之后就能正常访问。

技术分享
    /// 
    /// GetUserInfoAsync 的摘要说明
    /// 
    public class GetUserInfoAsync : HttpTaskAsyncHandler
    {
        private async Task 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遮罩层显示隐藏

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

标签:src   直接   lag   path   ash   inf   说明   报错   H5页面   

原文地址:http://www.cnblogs.com/wyt007/p/7798221.html


评论


亲,登录后才可以留言!