文档章节

MVC拦截器记录操作用户日志

码头地盘
 码头地盘
发布于 2017/08/29 09:57
字数 398
阅读 7
收藏 0

主要是用于记录用户操作动态,

 1 public class OperationAttribute:ActionFilterAttribute
 2 {
 3 /// <summary>
 4 /// 方法名称
 5 /// </summary>
 6 public string ActionName { get; set; }
 7 /// <summary>
 8 /// 控制器名称
 9 /// </summary>
10 public string ControllerName { get; set; }
11 /// <summary>
12 /// 方法参数
13 /// </summary>
14 public string ActionParameters { get; set; }
15 /// <summary>
16 /// 访问时间
17 /// </summary>
18 public DateTime AccessDate { get; set; }
19 /// <summary>
20 /// 登录用户
21 /// </summary>
22 public string LoginName { get; set; }
23 /// <summary>
24 /// 操作备注
25 /// </summary>
26 public string Operationremark { get; set; }
27 /// <summary>
28 /// 是否记录入库
29 /// </summary>
30 public bool IsLog { get; set; }
31 /// <summary>
32 /// 操作模块描述
33 /// </summary>
34 public string ModuleName { get; set; }
35 /// <summary>
36 /// 操作动作
37 /// </summary>
38 public string Option { get; set; }
39 
40 /// <summary>
41 /// 操作人id
42 /// </summary>
43 public int adminid { get; set; }
44 /// <summary>
45 /// 操作人名
46 /// </summary>
47 public string adminName { get; set; }
48 
49 public OperationAttribute()
50 {
51 this.AccessDate = DateTime.Now;
52 this.IsLog = true;
53 }
54 
55 /// <summary>
56 /// 
57 /// </summary>
58 /// <param name="moduleName">操作模块描述</param>
59 /// <param name="option">操作动作描述</param>
60 /// <param name="remark">其他备注</param>
61 public OperationAttribute(string moduleName, string option,string remark="")
62 {
63 this.AccessDate = DateTime.Now;
64 this.IsLog = true;
65 this.ModuleName = moduleName;
66 this.Option = option;
67 this.Operationremark = remark;
68 }
69 public override void OnActionExecuting(ActionExecutingContext filterContext)
70 {
71 if (this.IsLog)
72 {
73 //方法名称
74 this.ActionName = filterContext.ActionDescriptor.ActionName;
75 //控制器
76 this.ControllerName = filterContext.ActionDescriptor.ControllerDescriptor.ControllerName;
77 ///页面传递参数
78 IDictionary<string, object> dic = filterContext.ActionParameters;
79 var parameters = new System.Text.StringBuilder();
80 foreach (var item in dic)
81 {
82 parameters.Append(item.Key + "=" + item.Value + "|^|");
83 }
84 this.ActionParameters = parameters.ToString();
85 var userInfo = GetUserResultModel();
86 
87 //this.adminName = userInfo.userName;
88 
89 //this.adminid = userInfo.userid;
90 
91 //操作数据库记录
92  
93 
94 }
95 }

 

 

 

使用方法:

直接在action头上 加多特性[Operation("用户管理", "修改密码")] 就可以获取到用户操作的动作。

本文转载自:http://www.cnblogs.com/yjung/p/5368704.html

共有 人打赏支持
码头地盘
粉丝 0
博文 16
码字总数 0
作品 0
深圳
项目经理
私信 提问
Spring AOP 日志拦截器的事务管理

如果要在方法执行前或后或抛出异常后加上一个自己的拦截器,或者一个环绕拦截器,在拦截器中执行一些操作,比如执行一些数据库操作,记录一些信 息,这些操作通过调用一个服务类的方法来执行...

哲别0
05/18
0
0
[Abp 源码分析]十五、自动审计记录

0.简介 Abp 框架为我们自带了审计日志功能,审计日志可以方便地查看每次请求接口所耗的时间,能够帮助我们快速定位到某些性能有问题的接口。除此之外,审计日志信息还包含有每次调用接口时客...

myzony
09/29
0
0
SpringMVC处理器拦截器介绍及应用

常见应用场景 1、日志记录:记录请求信息的日志,以便进行信息监控、信息统计、计算PV(Page View)等。 2、权限检查:如登录检测,进入处理器检测检测是否登录,如果没有直接返回到登录页面...

楠木楠
2016/12/13
13
0
系统操作日志怎么保持比较好呢?

正在做一个项目,使用SSH框架。现在要求系统记录后台所有的操作日志,包括操作用户、操作类型、操作成功/失败、时间等等的详细信息都要记录,怎么做比较好呢? 是单独写一个日志模块在所有的...

mdaimon
2010/10/29
328
1
beetl错误处理类

beetl错误处理类 在使用beetl中如果${searchKey!}如果遗漏了"!"错误会在控制台输出、而没有记录到日志提醒中。一次线上环境出错没有及时拦截到错误记录被boss大吵、特此记录一下。经常出现的...

zzuqiang
2016/07/27
412
0

没有更多内容

加载失败,请刷新页面

加载更多

微服务分布式事务实现

https://www.processon.com/view/link/5b2144d7e4b001a14d3d2d30

WALK_MAN
今天
2
0
《大漠烟尘》读书笔记及读后感文章3700字

《大漠烟尘》读书笔记及读后感文章3700字: 在这个浮躁的社会里,你有多久没有好好读完一本书了? 我们总觉得自己和别人不一样,所以当看到别人身上的问题时,很少有“反求诸己”,反思自己。...

原创小博客
今天
4
0
大数据教程(9.5)用MR实现sql中的jion逻辑

上一篇博客讲解了使用jar -jar的方式来运行提交MR程序,以及通过修改YarnRunner的源码来实现MR的windows开发环境提交到集群的方式。本篇博主将分享sql中常见的join操作。 一、需求 订单数据表...

em_aaron
今天
3
0
十万个为什么之什么是resultful规范

起源 越来越多的人开始意识到,网站即软件,而且是一种新型的软件。这种"互联网软件"采用客户端/服务器模式,建立在分布式体系上,通过互联网通信,具有高延时(high latency)、高并发等特点...

尾生
今天
3
0
Terraform配置文件(Terraform configuration)

Terraform配置文件 翻译自Terraform Configuration Terraform用文本文件来描述设备、设置变量。这些文件被称为Terraform配置文件,以.tf结尾。这一部分将讲述Terraform配置文件的加载与格式。...

buddie
今天
5
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部