软件开发,离不开对日志的操作,它可以帮助我们查找和检测问题。好的日志组件可以对于整个系统来说,至关重要

在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的产品体系

最新文章

  1. 为select 设置样式
  2. JS(去掉前后空格或去掉所有空格)的用法
  3. percona-toolkit中在线ddl
  4. 【Alpha阶段】第四次Scrum例会
  5. Knockout.js, Asp.Net MVC and Bootstrap 前端设计
  6. apache开源项目--kylin
  7. MVC4 Razor视图下使用iframe加载RDLC报表
  8. 《第一行代码》学习笔记6-活动Activity(4)
  9. 两句话动态修改table数据并提交到后台
  10. [ SSH框架 ] Hibernate框架学习之二
  11. MicroService 微服务架构模式简述
  12. 多线程学习系列二(使用System.Threading)
  13. tiny4412 --Uboot移植(4) 串口
  14. 给area标签添加红色边框
  15. Create an Azure SQL database in the Azure portal
  16. awk 处理文本:行转列,列转行
  17. wagger的展示路径修改
  18. python单下划线与双下划线的区别
  19. oracle listagg函数、lag函数、lead函数 实例
  20. python-json.loads()保持原json字符串的顺序

热门文章

  1. Hibernate 的原生 SQL 查询
  2. C#编译成以管理员身份运行程序
  3. Azure Powershell使用已有特殊化非托管磁盘创建ARM虚拟机
  4. linux如何自动获取ip地址
  5. js_11_dom其他
  6. JAVA中科学计数法转换普通计数法
  7. MySQL备份利器-xtrabackup的介绍和原理(附脑图)
  8. java SimpleDateFormat日期与时间戳的相互转换
  9. 计算机中RAM和ROM
  10. “字符串替换” 和 “模板设置” (application/config.php)