当前位置: 首页 > news >正文

黄页网站大全免费网在线电子类 购物网站

黄页网站大全免费网在线,电子类 购物网站,美团企业邮箱认证怎么弄,公司商城网站开发费做什么科目目录 一、日志Sink(接收器) 二、Trace追踪实现日志 三、日志滚动 一、日志Sink(接收器) 安装NuGet包#xff1a;Serilog Sink有很多种#xff0c;这里介绍两种#xff1a; Console接收器#xff08;安装Serilog.Sinks.Console#xff09;; File接收器#xff08;安装…目录 一、日志Sink(接收器) 二、Trace追踪实现日志 三、日志滚动 一、日志Sink(接收器) 安装NuGet包Serilog Sink有很多种这里介绍两种                 Console接收器安装Serilog.Sinks.Console;                 File接收器安装Serilog.Sinks.File; MinimumLevel最小记录级别 rollingInterval:生成日志文件周期 outputTemplate:输出日志模板 继承ILogEventSink接口实现 Emit当Sink器接收到新日志时触发 通过该接口将接收器接收的日志添加进内部日志集合 将该接口实现类实例化对象通过WriteTo.Sink(myEventSink)与Logger绑定 实现 ILogEventSink接口示例 public Liststring Logs new Liststring();private readonly ITextFormatter _formatternew MessageTemplateTextFormatter(Message:{Message} [{Level}] Location:{FilePath}[{LineNumber}]);public void Emit(LogEvent logEvent){if (logEvent ! null){var textWriternew StringWriter();_formatter.Format(logEvent, textWriter);Logs.Add(textWriter.ToString());}} Main程序 MyEventSink myEventSink new MyEventSink();string path Logs\\Error\\.txt;string outputTemplate {NewLine}Date: {Timestamp:yyyy-MM-dd HH:mm:ss.fff}\tLevel: {Level}\tCallName: {SourceContext}-{MemberName} {NewLine}Path: {FilePath}[{LineNumber}] {NewLine}Message: {Message};Log.Logger new LoggerConfiguration().Enrich.FromLogContext()//记录相关上下文信息.MinimumLevel.Debug().WriteTo.Sink(myEventSink).WriteTo.Logger(log log.Filter.ByIncludingOnly(p p.Level LogEventLevel.Error).WriteTo.File(path, rollingInterval: RollingInterval.Day, outputTemplate: outputTemplate)).WriteTo.Console().CreateLogger();Log.Warning(*****************Warning***************);Log.Logger.Information(*******************Info****************);Log.Logger.CallErrorTest(#####################Error##################);foreach (string str in myEventSink.Logs){Console.WriteLine(str);} static class LogExtension{public static void CallErrorT(this ILogger logger, string message,[CallerMemberName] string meberName ,[CallerFilePath] string filepath ,[CallerLineNumber] int lineNum 0) logger.ForContextT().ForContext(MemberName, meberName).ForContext(FilePath, filepath).ForContext(LineNumber, lineNum).Error(message);public static void CallErrorT(this ILogger logger, Exception e, string message,[CallerMemberName] string meberName ,[CallerFilePath] string filepath ,[CallerLineNumber] int lineNum 0) logger.ForContextT().ForContext(MemberName, meberName).ForContext(FilePath, filepath).ForContext(LineNumber, lineNum).Error(e, message);} 二、Trace追踪实现日志 继承抽象类TraceListener重写方法TraceEvent 注意添加监听对象Trace.Listeners.Add(this); public override void TraceEvent(TraceEventCache? eventCache, string source, TraceEventType eventType, int id, string? message){switch (eventType){case TraceEventType.Error:Log.Logger.CallErrorMyTraceListen(message);break;case TraceEventType.Warning:Log.Logger.Warning(message);break;case TraceEventType.Information:Log.Logger.Information(message);break;default:break;}} 三、日志滚动 通过ObservableCollection类的CollectionChanged事件实现日志自动滚动到底部         集合改变触发事件更改附加属性AutoScroll值值更改触发CallBack将日志滚动到底部 注意MouseEnter与MouseLeave两事件的响应原因查看日志时防止日志自动滚动到底部 DataGrid attach:ScrollHelper.AutoScroll{Binding AutoScroll}AutoGenerateColumnsFalseCanUserAddRowsFalseCanUserDeleteRowsFalseCanUserReorderColumnsFalseCanUserResizeColumnsFalseCanUserResizeRowsFalseCanUserSortColumnsFalseItemsSource{Binding LogService.Logs}i:Interaction.Triggersi:EventTrigger EventNameMouseEnteri:InvokeCommandAction Command{Binding MouseEnterCommand} //i:EventTriggeri:EventTrigger EventNameMouseLeavei:InvokeCommandAction Command{Binding MouseLeaveCommand} //i:EventTrigger/i:Interaction.TriggersDataGrid.ColumnsDataGridTextColumn Binding{Binding Time} Header时间 /DataGridTextColumn Binding{Binding Lev} Header级别 /DataGridTextColumn Binding{Binding Message} Header信息DataGridTextColumn.ElementStyleStyleSetter PropertyTextBlock.TextWrapping ValueWrap /Setter PropertyTextBlock.TextAlignment ValueLeft //Style/DataGridTextColumn.ElementStyle/DataGridTextColumn/DataGrid.ColumnsDataGrid.RowStyleStyle TargetTypeDataGridRow BasedOn{StaticResource DataGridRowStyle}Style.TriggersDataTrigger Binding{Binding Lev} ValueErrorSetter PropertyForeground ValueRed//DataTriggerDataTrigger Binding{Binding Lev} ValueWarnSetter PropertyForeground ValueOrange//DataTrigger/Style.Triggers/Style/DataGrid.RowStyle/DataGrid public LogService LogService { get; set; }LogService.GetInstance();private bool _autoScroll;public bool AutoScroll{get { return _autoScroll; }set SetProperty(ref _autoScroll, value);}[RelayCommand]public void MouseEnter(){LogService._logs.CollectionChanged - Scroll;}[RelayCommand]public void MouseLeave(){LogService._logs.CollectionChanged Scroll;}private void Scroll(object sender, NotifyCollectionChangedEventArgs e){AutoScroll !AutoScroll;}public MainWinViewModel(){LogService.OpenListen();LogService._logs.CollectionChanged Scroll;}
http://www.hkea.cn/news/14399078/

相关文章:

  • 一个网站的建立需要什么同城推广引流平台
  • 怎么把网站放到服务器池州网站建设电话
  • 营销型网站建设应该考虑哪些因素会员管理系统哪个好用
  • 网站建设三把火科技wordpress自动给关键词加内链方法
  • 泰安哪个做网站wordpress 指定目录页
  • 电商网站布局设计营销型wordpress模板
  • 如何高效的完成网站建设步骤手工制作大全简单
  • 托管网站是什么意思软件开发工具教材
  • 罗湖网站建前端开发软件哪个最好
  • 我的网站首页打不开用户体验网站
  • 吉林响应式网站价格曲阜网站设计
  • 电子商务网站建设预算网站建设培训 店
  • 网站设置访问密码python做一个简单的网页
  • 社交网站 用户互黏度一级造价工程师吧
  • 图片外链上传网站展台设计搭建
  • 申请一个网站wordpress做seo优化
  • 推销网站的方法开发电子商务系统的五个步骤
  • 网站可能存在什么问题吗网站图片浏览特效
  • 网站建设中长出现的问题网站建设公司倒闭
  • 长春做网站公司长春seo公司ppt模板怎么套用
  • 福州网站建设吧腾讯云网站建设教学视频
  • 门户网站运营门户网站免费建站
  • 深圳做小程序网站设计益阳做网站怎么便宜
  • 白银市建设局网站网站建设公司渠道
  • 富阳网站公司西安网站开发服务费用
  • 做国际网站多少钱wordpress 修改端口号
  • 用路由侠做网站西安做行业平台网站的公司
  • 影视自助建站系统源码网站的设计开发
  • 天津手机模板建站专业做家电经销的网站
  • 网站开发太简单了框架手机网站开发工具 2018