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

有网站吗推荐一下广西兴业县建设局网站

有网站吗推荐一下,广西兴业县建设局网站,网站建设的岗位名称,居民瑞app下载目录 一、日志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.tj-hxxt.cn/news/141588.html

相关文章:

  • asp个人网站模板下载网站开发公司如何拓展业务
  • 网站优化多少钱苏州知名互联网公司
  • 西双版纳建设厅网站专业建站培训
  • 装饰公司网站模版公司网站建设设计服务
  • 高端网站建设公司哪家服务态度好第三方推广平台
  • 建企业网站要多少钱网站优秀作品
  • 怎么做加密货币网站外贸SOHO建公司网站
  • jk网站建设网页怎么制作动画
  • 县区网站集约化平台建设研究传奇开服网
  • 网站头部固定优化网站步骤
  • 可信网站友链怎么做网站建设飠金手指排名十二
  • 万网云服务器怎么上传网站单页网站怎么卖
  • 龙岗网站制作公司成都市网站建设
  • 上海长宁网站建设网页版qq游戏大厅
  • 哪个网站可以做社工试题网页设计作品特色及亮点
  • app的网站域名注册便宜高端网站设计
  • 一起装修网官方网站公司网站建设的范文
  • 个人信息网站模板商品图片网站开发
  • 如何在电影网站中做淘客wordpress 虚拟商品插件
  • 丽水市做网站的网站数据库模板下载
  • 临汾哪里有做网站的贵州企业网站建设公司
  • 电子政务网站建设收到网站代码后怎么做
  • 字母logo设计网站创新的大良网站建设
  • 网站备案期间可以用二级域名访问网站吗哈尔滨网站设计定制
  • 网站开发入门书如何做内容收费的网站
  • 网站建设需要材料开发游戏用什么编程软件
  • wordpress数据库密码加密多少位太原网站seo顾问
  • 国内免费产品发布网站工作室建设规划
  • 做网站公司上什么平台宁波网络公司网站建s
  • 温州做网站哪家公司好甘肃锦华建设集团网站