基于Ado.Net的日志组件
2024-08-26 23:15:57
软件开发,离不开对日志的操作,它可以帮助我们查找和检测问题。好的日志组件可以对于整个系统来说,至关重要
在NaviSoft产品中,日志组件也占有非常重要的份量。如下图所示,是组件的Db表结构设计
图-1
登录日志:记录系统的登录信息,包括登录用户、登录时间、客户端信息
操作日志:记录每个功能操作信息,包括操作时间、内容和结果
异常错误日志:当整个系统
方法日志:记录每个方法的名称、参数、返回值、所在类和DLL等。用于分析方法执行时间,排查错误
API操作日志:记录API操作日志
API异常错误日志:记录API执行异常日志
API调用次数日志:记录API调用次数日志,防止超出调用次数
临时记录表:记录自定义的日志内容,只有一个字符串,可随意保存内容
整个日志组件,采用Ado.Net方式与Db交互,这也是有原因的:NaviSoft本身是采用EF作为Db组件,若日志也使用此组件,容易产生嵌套事务错误,如:保存日志失败时。部分源码如下图所示
/// <summary>
/// 保存登录日志
/// </summary>
/// <param name="modelLog"></param>
public static void SaveLogon(loglogonBillModel modelLog)
{
if (modelLog == null) return; DbSqlAndParam dbSql = dbService.GeneSqlAndParamToInsert<loglogonBillModel>(modelLog, "log_logon");
dbService.ExecSqlAndParamByTrans(new List<DbSqlAndParam>() { dbSql });
}
另外,NaviSoft的日志组件,也将log4net的源码移植进来,如下图所示
图-2
此日志组件在NaviSoft产品体系中,同时应用于WinForm、WebMVC、Mobile三个场景的产品,后续将分别介绍NaviSoft的产品体系
最新文章
- 为select 设置样式
- JS(去掉前后空格或去掉所有空格)的用法
- percona-toolkit中在线ddl
- 【Alpha阶段】第四次Scrum例会
- Knockout.js, Asp.Net MVC and Bootstrap 前端设计
- apache开源项目--kylin
- MVC4 Razor视图下使用iframe加载RDLC报表
- 《第一行代码》学习笔记6-活动Activity(4)
- 两句话动态修改table数据并提交到后台
- [ SSH框架 ] Hibernate框架学习之二
- MicroService 微服务架构模式简述
- 多线程学习系列二(使用System.Threading)
- tiny4412 --Uboot移植(4) 串口
- 给area标签添加红色边框
- Create an Azure SQL database in the Azure portal
- awk 处理文本:行转列,列转行
- wagger的展示路径修改
- python单下划线与双下划线的区别
- oracle listagg函数、lag函数、lead函数 实例
- python-json.loads()保持原json字符串的顺序
热门文章
- Hibernate 的原生 SQL 查询
- C#编译成以管理员身份运行程序
- Azure Powershell使用已有特殊化非托管磁盘创建ARM虚拟机
- linux如何自动获取ip地址
- js_11_dom其他
- JAVA中科学计数法转换普通计数法
- MySQL备份利器-xtrabackup的介绍和原理(附脑图)
- java SimpleDateFormat日期与时间戳的相互转换
- 计算机中RAM和ROM
- “字符串替换” 和 “模板设置” (application/config.php)