using BPASmartClient.CustomResource.UserControls; using BPASmartClient.CustomResource.UserControls.MessageShow; using BPASmartClient.Helper; using BPASmartClient.Model; using Microsoft.Toolkit.Mvvm.ComponentModel; using Microsoft.Toolkit.Mvvm.Input; using System; using System.Collections.Generic; using System.Collections.ObjectModel; using System.ComponentModel; using System.Data; using System.IO; using System.Linq; using System.Text; using System.Text.RegularExpressions; using System.Threading.Tasks; using System.Windows.Media; namespace BPASmartClient.ViewModel { /// /// 告警/日志查询界面 /// public class LogOrAlarmViewModel : ObservableObject { #region 单一变量 private volatile static LogOrAlarmViewModel _Instance; public static LogOrAlarmViewModel GetInstance() => _Instance ?? (_Instance = new LogOrAlarmViewModel()); private LogOrAlarmViewModel() { Init(); } #endregion #region 变量 string path = $"{System.AppDomain.CurrentDomain.BaseDirectory}LogDir\\HBL.LogDir2022_5_13.log"; private string _SelectedText = ""; public string SelectedText { get { return _SelectedText; } set { if (_SelectedText == value) return; _SelectedText = value; OnPropertyChanged("SelectedText"); } } /// /// 时间条件 /// private DateTime _DateTime; public DateTime DateTimeStr { get { return _DateTime; } set { if (_DateTime == value) return; _DateTime = value; OnPropertyChanged("DateTimeStr"); } } public ObservableCollection SelectBookExs { set; get; } private ObservableCollection _books; public ObservableCollection BookExs { get { if (_books == null) { _books = new ObservableCollection(); _books.CollectionChanged += (sender, e) => { if (e.OldItems != null) { foreach (BookEx bookEx in e.OldItems) { bookEx.PropertyChanged -= ItemPropertyChanged; } } if (e.NewItems != null) { foreach (BookEx bookEx in e.NewItems) { bookEx.PropertyChanged += ItemPropertyChanged; } } }; } return _books; } } private ObservableCollection _LogModels; public ObservableCollection LogDataGrid { get { return _LogModels; } set { if (_LogModels == value) return; _LogModels = value; OnPropertyChanged("LogDataGrid"); } } public string SearchText { get { return _mSearchText; } set { _mSearchText = value; OnPropertyChanged(); } } private string _mSearchText; #endregion #region Command public RelayCommand QueryCommand { get; set; } public RelayCommand OpenCommand { get; set; } #endregion #region 函数 public void Init() { LogDataGrid = new ObservableCollection(); DateTimeStr = DateTime.Now; BookExs.Add(new BookEx(new Book() { Name = "一般日志条件", Tag = "Info" }) { IsChecked = true }); BookExs.Add(new BookEx(new Book() { Name = "设备日志条件", Tag = "DeviceLog" }) { IsChecked = true }); BookExs.Add(new BookEx(new Book() { Name = "错误日志条件", Tag = "Error" }) { IsChecked = true }); BookExs.Add(new BookEx(new Book() { Name = "设备告警条件", Tag = "DeviceAlarm" }) { IsChecked = true }); SelectBookExs = new ObservableCollection(); ItemPropertyChanged(new BookEx(new Book()) { IsChecked = true }, new PropertyChangedEventArgs("IsChecked")); //查询 QueryCommand = new RelayCommand(() => { string sql = string.Empty; if (SelectBookExs.Count <= 0) { NoticeDemoViewModel.OpenMsg(EnumPromptType.Info, MainViewModel.GetInstance().window, "提示", $"至少选中一个条件!"); return; } SelectBookExs?.ToList().ForEach(par => { if (string.IsNullOrEmpty(sql)) sql += $"LOGGER='{par.BookN.Tag}'"; else sql += $" OR LOGGER='{par.BookN.Tag}'"; }); //1.找到某天的文件 string path = $"{System.AppDomain.CurrentDomain.BaseDirectory}LogDir\\HBL.LogDir{DateTimeStr.ToString("yyyy_M_d")}.log"; if (File.Exists(path)) { LogDataGrid.Clear(); //2.根据选中查询日志 DataTable dataTable = ReadFile(path); List datas = dataTable.Select($"({sql})").OrderByDescending(o => o["TIME"])?.ToList(); if (datas == null || datas.Count() <= 0) { NoticeDemoViewModel.OpenMsg(EnumPromptType.Info, MainViewModel.GetInstance().window, "提示", $"查询结果为空!"); return; } foreach (DataRow item in datas) { LogDataGrid.Add(new LogModel { time = item["TIME"].ToString(), type = item["LOGGER"].ToString(), message = item["MESSAGE"].ToString() // foreground = (item["LOGGER"].ToString() == "ERROR" || item["LOGGER"].ToString() == "DEVICEALARM") ? new SolidColorBrush((System.Windows.Media.Color)System.Windows.Media.ColorConverter.ConvertFromString("#ed0032")) : new SolidColorBrush((System.Windows.Media.Color)System.Windows.Media.ColorConverter.ConvertFromString("#21bb2e")) }); } if (SearchText?.Length > 0) { var SearchList = LogDataGrid.Where(p => p.message.Contains(SearchText)).ToList(); if (SearchList != null && SearchList.Count > 0) { LogDataGrid.Clear(); SearchList.ForEach((item) => { LogDataGrid.Add(item); }); } } } else { NoticeDemoViewModel.OpenMsg(EnumPromptType.Info, MainViewModel.GetInstance().window, "提示", $"文件不存在,{path}!"); } }); //打开文件目录 OpenCommand = new RelayCommand(() => { System.Diagnostics.Process.Start("Explorer", "/select," + logHelper.GetLogConfigInstance().directRollfileAppender.File); logHelper.GetLogConfigInstance().OpenFile(logHelper.GetLogConfigInstance().directRollfileAppender.File); }); } /// /// 读取文件 /// /// public DataTable ReadFile(string path) { DataTable dt = new DataTable(); dt.Columns.AddRange(new[] { new DataColumn("TIME"), new DataColumn("LOGGER"), new DataColumn("NAME"), new DataColumn("PRIORITY"), new DataColumn("MESSAGE"), }); //读取文件 string s = ""; using (FileStream fs = new FileStream(path, FileMode.Open, FileAccess.Read, FileShare.ReadWrite)) { using (StreamReader sr = new StreamReader(fs, System.Text.Encoding.Default)) { s = sr.ReadToEnd(); } } //正则表达式匹配,注意RegexOptions.RightToLeft var matches = Regex.Matches(s, @"(\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2}) ([A-Z, ]{0,15}) ([A-Z,a-z]{0,20}) (\[\d{1}\]) (.*)", RegexOptions.RightToLeft); foreach (Match m in matches) { var time = m.Groups[1].Value; var logger = m.Groups[2].Value; var name = m.Groups[3].Value; var priority = m.Groups[4].Value; var msg = m.Groups[5].Value; var dr = dt.NewRow(); dr.ItemArray = new[] { time, logger, name, priority, msg }; dt.Rows.InsertAt(dr, 0); } return dt; } /// /// 选中改变 /// /// /// private void ItemPropertyChanged(object sender, PropertyChangedEventArgs e) { if (e.PropertyName == "IsChecked") { BookEx bookEx = sender as BookEx; if (bookEx != null) { IEnumerable bookExs = BookExs.Where(b => b.IsChecked == true); StringBuilder builder = new StringBuilder(); SelectBookExs.Clear(); foreach (BookEx item in bookExs) { builder.Append(item.BookN.Name + " "); SelectBookExs.Add((BookEx)item); } SelectedText = builder == null ? string.Empty : builder.ToString(); } } } #endregion } }