Win10手记-为应用集成日志工具Logger
日志工具由来已久,是很受大家欢迎的debug工具。其中.NET平台上很出名的是log4net,但是由于Windows 10通用应用项目没有了System.Configuration引用,所以也就不能很好使用log4net工具了。
Windows Runtime框架大家从它面世以来一直在吐槽,log4net也因为其缺少api不能使用,但是我们仍然可以找到替代方案。Windows.Foundation.Diagnostics命名空间下就提供了一套简单的日志工具,能够正常使用下去。
方案
根据MSDN查到的信息,Windows Runtime API中的LoggingChannel和logSession类提供了所需的功能,官方也封装了一段示例代码。在此基础上,我又进一步封装了一下:
public class LogManager
{
public static void Log(string message)
{
Logger.GetLogger().logChannel.LogMessage(message, LoggingLevel.Information);
}
public static void LogError(string message)
{
Logger.GetLogger().logChannel.LogMessage(message, LoggingLevel.Error);
} public static void InitiateLogger()
{
Logger.GetLogger().InitiateLogger();
Logger.GetLogger().Deletefile();
}
}
class Logger
{ public LoggingChannel logChannel; public LoggingSession logSession; private StorageFolder logUploadFolder; public const string LOG_SESSION_RESROUCE_NAME = "LogSession"; static private Logger logger;
private const int DAYS_TO_DELETE = ; public async void InitiateLogger()
{
logChannel = new LoggingChannel("YSYChannel",null);
logSession = new LoggingSession("YSY Session"); logSession.AddLoggingChannel(logChannel); await RegisterUnhandledErrorHandler();
} /// <summary>
/// 单例
/// </summary>
/// <returns></returns>
static public Logger GetLogger()
{
if (logger == null)
{
logger = new Logger();
}
return logger;
} private async Task RegisterUnhandledErrorHandler()
{
logUploadFolder = await ApplicationData.Current.LocalFolder.CreateFolderAsync("MyLogFile",
CreationCollisionOption.OpenIfExists); CoreApplication.UnhandledErrorDetected += CoreApplication_UnhandledErrorDetected; } /// <summary>
/// 处理任何未处理的异常
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private async void CoreApplication_UnhandledErrorDetected(object sender, UnhandledErrorDetectedEventArgs e)
{
try
{
logChannel.LogMessage("Caught the exception");
e.UnhandledError.Propagate(); }
catch (Exception ex)
{
logChannel.LogMessage($"UnhandledErro: {ex.Message}", ex.Message), LoggingLevel.Critical);
//logChannel.LogMessage(string.Format("Effor Message: {0}", ex.Message)); if (logSession != null)
{
//var filename = DateTime.Now.ToString("yyyyMMdd-HHmmssTzz") + ".etl";
var filename = DateTime.Now.ToString("yyyyMMdd") + ".etl";
var logSaveTast =await logSession
.SaveToFileAsync(logUploadFolder, filename);
} // throw;
}
} /// <summary>
/// 删除之前日期的日志
/// </summary> public async void Deletefile()
{
try
{ var logFiles = await logUploadFolder.GetFilesAsync(); foreach (var logFile in logFiles)
{
if ((DateTime.Now - logFile.DateCreated).Days > DAYS_TO_DELETE)
{
await logFile.DeleteAsync();
} }
}
catch (Exception ex)
{
logChannel.LogMessage(ex.Message); }
} }
使用
Logger类采用单例写法,使用之前我们需要先进行初始化。一般我们应当在App.xaml.cs文件中的OnLaunch方法中调用初始化方法,如下:
protected override void OnLaunched(LaunchActivatedEventArgs e)
{
//初始化日志工具
LogManager.InitiateLogger();
LogManager.Log("应用启动");
}
初始化方法会在应用独立存储目录下创建一个MyLogFile日志文件夹,当日的日志文件将会在此文件夹中创建。
下面代码则会将http错误请求信息写入进此日志文件,以供我们后续处理。
catch(Exception ex)
{
LogManager.LogError($"http请求错误:{ex.Message}");
}
我们可以在应用独立存储文件夹中看到我们的日志文件,如下:

双击打开日志文件后,即可在Windows行为分析器中查看详细信息,如下:

总结
以上日志工具为目前可选的方案,同时我们也可很容易自己写一套基于文本输出的日志工具,随着Windows 10的普及,会有更多更好用的框架出现。
Win10手记-为应用集成日志工具Logger的更多相关文章
- Win10手记-为应用集成SQLite(一)
SQLite是什么?熟悉移动端开发的朋友都会经常接触,无论是iOS的CoreData还是安卓的内置数据库,他们都是采用了SQLite这个轻量高效数据库,微信也是如此.可以说SQLite是目前移动端最为 ...
- Win10手记-为应用集成SQLite(二)
接上篇内容,这里给大家分享我的辅助访问类,采用了异步方法,封装了常用的访问操作,一些操作还是纯CLI的. SQLiteDBManager using System; using System.Coll ...
- Java日志工具之java.util.logging.Logger
今天总结下JDK自带的日志工具Logger,虽然它一直默默无闻,但有时使用它却比较方便.更详细的信息可以查看JDK API手册,本文只是简单示例入门. 创建Logger 我们可以使用Logger的工厂 ...
- .NetCore中的日志(2)集成第三方日志工具
.NetCore中的日志(2)集成第三方日志工具 0x00 在.NetCore的Logging组件中集成NLog 上一篇讨论了.NetCore中日志框架的结构,这一篇讨论一下.NetCore的Logg ...
- SAP ABAP RFC接口通用日志工具:abap fm logger
很早之前就想写个能记录函数模块日志的通用工具,最早尝试时,没有想清楚插入代码的体积问题.在一些群友的提醒下,了解到可以用宏来处理这一问题.不过当时比较忙,就没有动笔.最近又想起这件事,花了2天完成了一 ...
- 细说Java主流日志工具库
概述 在项目开发中,为了跟踪代码的运行情况,常常要使用日志来记录信息. 在Java世界,有很多的日志工具库来实现日志功能,避免了我们重复造轮子. 我们先来逐一了解一下主流日志工具. java.util ...
- Java主流日志工具库
在项目开发中,为了跟踪代码的运行情况,常常要使用日志来记录信息.在Java世界,有很多的日志工具库来实现日志功能,避免了我们重复造轮子.我们先来逐一了解一下主流日志工具. 1.java.util.lo ...
- 权限管理系统之项目框架搭建并集成日志、mybatis和分页
前一篇博客中使用LayUI实现了列表页面和编辑页面的显示交互,但列表页面table渲染的数据是固定数据,本篇博客主要是将固定数据变成数据库数据. 一.项目框架 首先要解决的是项目框架问题,搭建什么样的 ...
- SpringBoot学习笔记(五):SpringBoot集成lombok工具、SpringBoot集成Shiro安全框架
SpringBoot集成lombok工具 什么是lombok? 自动生成setget方法,构造函数,打印日志 官网:http://projectlombok.org/features/index. 平 ...
随机推荐
- layui-tree创建下拉树型选项框
1.简介 也许你对树菜单再熟悉不过了,然而你仍有可能更青睐layui的tree,它也许比以往你知道的任何一个类似的组件都更轻量.简单,你在享受许多功能的同时,甚至不用去记太多的参数. 另外,最大的重点 ...
- cdnbest独立主控配置自定义错误页面
注:自定义错误的域名最好配置ssl,不配碰到有使用ssl的域名,错误码显示就会有问题 (1)登陆管理后台点区域列表-->配置-->错误url 解析一个域名到你的cdn主控,然后输入这个ur ...
- cdnbest架设cdn同一个源用不同的端口访问如何设置
在站点里的应用防火墙-->高级设置里配置 比如test.com要同时用80和88访问
- sqlserver truncate清空表时候,无法删除 'B表',因为该表正由一个 FOREIGN KEY 约束引用。
外键: 查询:select object_name(a.parent_object_id) 'tables' from sys.foreign_keys a where a.referenced_ ...
- Spark2.0学习(一)--------Spark简介
官网对Spark的介绍 http://spark.apache.org/ Apache Spark™ is a unified analytics engine for large-scale dat ...
- Unity3D 导入aar注意事项
导出供Unity使用的*.aar文件 1)点击“Build -> Build APK”,生成aar文件 2)由于Unity在打包APK时会自动包含自身的classes.jar,所以需使用压缩软件 ...
- C++字符串结束标识
用一个字符数组可以存放一个字符串中的字符.如: char str[12]={'I',' ','a','m',' ','h','a','p','p','y'}; 用一维字符数组str来存放一个字符串″I ...
- linux ">/dev/null 2>&1 &"
0:表示键盘输入(stdin)1:表示标准输出(stdout),系统默认是1 2:表示错误输出(stderr) command >/dev/null 2>&1 & == ...
- (O)WEB:前端网站性能优化(原创)
*从理论.实战编码.实战调试3个方面学习前端性能优化(包括页面加载时间和页面流畅度): -------------------------------理论----------------------- ...
- NC 自定义参照类
package nc.ui.hzctr.costctr.ref; import nc.ui.bd.ref.AbstractRefModel; import nc.vo.pubapp.pattern.p ...