zoukankan      html  css  js  c++  java
  • 利用ASP .NET Core的静态文件原理实现远程访问Nlog日志内容及解决遇到的坑

          最近项目上试运行发现,很多时候网站出了问题或者某个功能不正常,常常需要运维人员去服务器里面查看一下日志,看看日志里面会产生什么异常,这样导致每次都要去远程服务器很不方便,有时服务器是客户保管的不能让我们随意远程,最后想到静态文件方法将log日志读出来打印到网页上就可以替换远程服务器找到对应log日志的目录,节省了时间和沟通成本;另:我们是局域内网系统不是互联网所以对安全不用太考虑,这样才能把日志输出到页面上面,如果互联网产品或者安全比较高的不建议这么做

          简单说一下实现步骤:

            一、 首先我们是通过Nlog来记录日志的,Nlog怎么使用我这不介绍了,在上篇文章已有说明

           二、 在Startup类Configure中加入静态文件路由的方式

     #region 远程读取日志
                FileExtensionContentTypeProvider provider = new FileExtensionContentTypeProvider(); 
                provider.Mappings[".log"] = "text/plain";
                string basePath = Path.GetDirectoryName(typeof(Program).Assembly.Location);
                app.UseStaticFiles(new StaticFileOptions()
                {
                    FileProvider = new PhysicalFileProvider(Path.Combine(basePath, "logs")),
                    ServeUnknownFileTypes = true,
                    RequestPath = new PathString("/logs"),
                    ContentTypeProvider = provider,
                    DefaultContentType = "application/x-msdownload", // 设置未识别的MIME类型一个默认z值
    
                });
                app.UseDirectoryBrowser(new DirectoryBrowserOptions()
                {
                    FileProvider = new PhysicalFileProvider(Path.Combine(basePath, "logs")),
                    RequestPath = new PathString("/logs"),
                });
                #endregion

           三、运行界面:

          

          四、点击需要查看的日志发现 中文都是乱码

       五、然而直接通过文件打开日志,并不显示乱码,大致判断应该是读写的编码格式不对

     

        六、以上验证  这样说明不是Nlog写入的时候为乱码,最后考虑是不是读取的时候输出为乱码,我自己在logs文件夹下面建了一个text文件,利用网页读取信息,也不是乱码,如图所示:

          七、经过多次验证发现2个问题:1.Nlog在写入日志建日志文件的时候编码格式为default,实际格式ANSI,需要把文件改成通用编码UTF-8 ; 

                                                        这样直接在nlog配置文件 文件写入规则里面加一个编码设置【encoding="utf-8"】

                                                         2. 读取.log类型时必须也要设置读取类型

                                                        这样直接将 provider.Mappings[".log"] = "text/plain"; 修改为 provider.Mappings[".log"] = "text/plain;charset=utf-8";

             八、     运行验证,中文没有乱码

        Demo源码Git地址:https://github.com/lxshwyan/QuartzDemo.git

                                

  • 相关阅读:
    win7(64)未在本地计算机上注册“Microsoft.Jet.OLEDB.4.0”提供程序的解决办法
    很方便的工具——代码生成工具之Winform查询列表界面生成
    程序员十几个常用网站
    优秀程序员不得不知道的20个位运算技巧
    unset()索引数组
    git 撤销修改
    git 版本回退
    git 命令详解
    git多账户配置
    Git的.ssh文件夹的内容
  • 原文地址:https://www.cnblogs.com/lxshwyan/p/10910315.html
Copyright © 2011-2022 走看看