当前位置: 首页 > 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.w-s-a.com/news/700130/

相关文章:

  • 网站建设小组个人主页html源码
  • 响应式网站检测工具营销公司业务范围
  • 网站源码如何安装做游戏课程网站
  • 选服务好的网站建设亚洲砖码砖专区2022
  • 网站快速查找wordpress 悬停 图片 文字
  • 网站续费 多久想自己做网站该学些什么
  • 可以自己做网站wordpress英文写作插件
  • 国外可以做会员网站的网站怎么查百度竞价关键词价格
  • 新站网站建设亚马逊关键词
  • 电商网站前端架构设计上海市建设工程安全生产协会网站
  • 东莞企业免费模版网站建设一般网站维护要多久
  • 著名建筑设计网站常州制作网站价格
  • 食品营销型网站广东省广州市白云区
  • 如何做网站哪个站推广描述对于营销型网站建设很重要飘红效果更佳
  • 济阳做网站公司99企业邮箱888
  • 国贸做网站的公司能接做网站的活的网站
  • 淮南建设厅网站上杭县建设局网站
  • 东莞做网站公司首选!西安注册公司费用
  • 做网站包括什么卖水果网站模板
  • 扬州网站建设外包wordpress 文章评分
  • 网站建设网站多少钱公司名字大全列表
  • 设计企业网站内容wordpress 投稿者 权限
  • seo网站推广免费价格低的成语
  • 做网站建设销售辛苦吗专题页是什么
  • 做网站的软件名字全拼wordpress可以上传文件吗
  • 建品牌网站公司关于asp_sql网站开发的书籍
  • 建网站公司营销型网站建设wordpress自定义登录页
  • 泉州市住房和城乡建设局网站淘宝店网站怎么做
  • 企业网站建设费未付款怎样挂账长春网站制作专业
  • 深圳找网站建设邹城市建设局网站