2019-03-22 15:46:32 +08:00
|
|
|
using Bootstrap.Admin.Query;
|
2018-06-07 00:45:47 +08:00
|
|
|
using Longbow.Web.Mvc;
|
|
|
|
using Microsoft.AspNetCore.Mvc;
|
|
|
|
using System;
|
|
|
|
using System.Collections.Generic;
|
|
|
|
using System.IO;
|
|
|
|
using System.Linq;
|
|
|
|
using System.Text;
|
|
|
|
|
|
|
|
namespace Bootstrap.Admin.Controllers.Api
|
|
|
|
{
|
|
|
|
/// <summary>
|
|
|
|
///
|
|
|
|
/// </summary>
|
|
|
|
[Route("api/[controller]")]
|
2018-11-24 15:12:44 +08:00
|
|
|
[ApiController]
|
|
|
|
public class ExceptionsController : ControllerBase
|
2018-06-07 00:45:47 +08:00
|
|
|
{
|
|
|
|
/// <summary>
|
|
|
|
/// 显示所有异常
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="value"></param>
|
|
|
|
/// <returns></returns>
|
|
|
|
[HttpGet]
|
2018-11-24 15:12:44 +08:00
|
|
|
public QueryData<object> Get([FromQuery]QueryExceptionOption value)
|
2018-06-07 00:45:47 +08:00
|
|
|
{
|
2019-01-11 23:20:28 +08:00
|
|
|
return value.Retrieves();
|
2018-06-07 00:45:47 +08:00
|
|
|
}
|
2019-01-11 23:20:28 +08:00
|
|
|
|
2018-06-07 00:45:47 +08:00
|
|
|
/// <summary>
|
2019-03-22 15:46:32 +08:00
|
|
|
/// 异常程序页面点击服务器日志按钮获取所有物理日志文件列表方法
|
2018-06-07 00:45:47 +08:00
|
|
|
/// </summary>
|
|
|
|
/// <returns></returns>
|
|
|
|
[HttpPost]
|
2019-03-22 15:46:32 +08:00
|
|
|
[ButtonAuthorize(Url = "~/Admin/Exceptions", Auth = "log")]
|
2018-06-07 00:45:47 +08:00
|
|
|
public IEnumerable<string> Post()
|
|
|
|
{
|
|
|
|
var filePath = Path.Combine(AppContext.BaseDirectory, "Error");
|
2019-01-17 12:13:30 +08:00
|
|
|
return Directory.Exists(filePath)
|
|
|
|
? Directory.GetFiles(filePath)
|
2018-09-10 18:43:16 +08:00
|
|
|
.Where(f => Path.GetExtension(f).Equals(".log", StringComparison.OrdinalIgnoreCase))
|
2019-01-17 12:13:30 +08:00
|
|
|
.Select(f => Path.GetFileNameWithoutExtension(f)).OrderByDescending(s => s)
|
|
|
|
: Enumerable.Empty<string>();
|
2018-06-07 00:45:47 +08:00
|
|
|
}
|
2019-01-11 23:20:28 +08:00
|
|
|
|
2018-06-07 00:45:47 +08:00
|
|
|
/// <summary>
|
2019-03-22 15:46:32 +08:00
|
|
|
/// 选中指定文件查看其内容方法
|
2018-06-07 00:45:47 +08:00
|
|
|
/// </summary>
|
|
|
|
/// <returns></returns>
|
|
|
|
[HttpPut]
|
2019-03-22 15:46:32 +08:00
|
|
|
[ButtonAuthorize(Url = "~/Admin/Exceptions", Auth = "log")]
|
2018-06-07 00:45:47 +08:00
|
|
|
public JsonResult Put([FromBody]ExceptionFileQuery exceptionFile)
|
|
|
|
{
|
|
|
|
var filePath = Path.Combine(AppContext.BaseDirectory, "Error");
|
|
|
|
var logName = $"{Path.Combine(filePath, exceptionFile.FileName)}.log";
|
|
|
|
if (!System.IO.File.Exists(logName)) return new JsonResult("无此日志文件");
|
|
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
using (StreamReader reader = new StreamReader(logName))
|
|
|
|
{
|
|
|
|
while (!reader.EndOfStream)
|
|
|
|
{
|
|
|
|
var line = reader.ReadLine().Replace("<", "<").Replace(">", ">");
|
|
|
|
if (line == "General Information ") sb.AppendFormat("<h4><b>{0}</b></h4>", line);
|
|
|
|
else if (line.StartsWith("TimeStamp:")) sb.AppendFormat("<div class='logTs'>{0}</div>", line);
|
|
|
|
else if (line.EndsWith("Exception Information")) sb.AppendFormat("<div class='logExcep'>{0}</div>", line);
|
|
|
|
else if (line.StartsWith("Message:")) sb.AppendFormat("<div class='logMsg'>{0}</div>", line);
|
|
|
|
else if (line.StartsWith("ErrorSql:")) sb.AppendFormat("<div class='logSql'>{0}</div>", line);
|
|
|
|
else if (line.StartsWith("Exception Type: Longbow.Data.DBAccessException")) sb.AppendFormat("<div class='logDbExcep'>{0}</div>", line);
|
|
|
|
else if (line.StartsWith("StackTrace Information")) sb.AppendFormat("<b>{0}</b><br>", line);
|
|
|
|
else sb.AppendFormat("{0}<br>", line);
|
2019-03-22 15:46:32 +08:00
|
|
|
}
|
2018-06-07 00:45:47 +08:00
|
|
|
}
|
|
|
|
return new JsonResult(sb.ToString());
|
|
|
|
}
|
2019-01-11 23:20:28 +08:00
|
|
|
|
2018-10-28 15:08:58 +08:00
|
|
|
/// <summary>
|
|
|
|
///
|
|
|
|
/// </summary>
|
2018-06-07 00:45:47 +08:00
|
|
|
public class ExceptionFileQuery
|
|
|
|
{
|
2018-10-28 15:08:58 +08:00
|
|
|
/// <summary>
|
|
|
|
///
|
|
|
|
/// </summary>
|
2018-06-07 00:45:47 +08:00
|
|
|
public string FileName { get; set; }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|