1.看似针对同样一段查询表ef达式,重复执行却没有被记录下来。其实这是正常情况,因为ef并没有重复去执行 相同sql查询。

2.MiniProfiler结合MVC过滤器进行 拦截记录Sql,示例代码:

using Mobile360.Core;
using Mobile360.Core.Interfaces;
using Mobile360.Core.Models;
using Mobile360.Web.Common;
using Newtonsoft.Json.Linq;
using StackExchange.Profiling;
using StackExchange.Profiling.Storage;
using System;
using System.Collections.Generic;
using System.Collections.Specialized;
using System.Configuration;
using System.Linq;
using System.Text;
using System.Web;
using System.Web.Helpers;
using System.Web.Mvc; namespace Mobile360.Web
{
[AttributeUsage(AttributeTargets.Method, AllowMultiple = true, Inherited = false)]
public class OperationHandlerAttribute : FilterAttribute,IActionFilter, IExceptionFilter
{
private IRepository repo; /// <summary>
/// 模块描述
/// </summary>
public string ModuleName { get; set; } /// <summary>
/// 方法名称
/// </summary>
public string ActionName { get; set; } /// <summary>
/// 方法描述
/// </summary>
public string ActionDescription { get; set; } /// <summary>
/// 控制器名称
/// </summary>
public string ControllerName { get; set; } /// <summary>
/// 方法参数
/// </summary>
public string ActionParameters { get; set; } /// <summary>
/// 访问时间
/// </summary>
public DateTime AccessDate { get; set; } /// <summary>
/// 操作备注
/// </summary>
public string OperationRemark { get; set; } /// <summary>
/// 是否记录入库
/// </summary>
public bool IsLog { get; set; } /// <summary>
/// 操作人id
/// </summary>
public int OperatorId { get; set; } /// <summary>
/// 操作人名
/// </summary>
public string OperatorName { get; set; } public OperationHandlerAttribute()
{
this.AccessDate = DateTime.Now;
this.IsLog = true;
this.repo = DependencyResolver.Current.GetService<IRepository>();
} /// <summary>
/// 操作日志记录
/// </summary>
/// <param name="option">操作动作描述</param>
/// <param name="remark">其他备注</param>
public OperationHandlerAttribute(string actionDescription , string remark = "")
{
this.AccessDate = DateTime.Now;
this.IsLog = true;
//this.ModuleName = moduleName;
this.OperationRemark = remark;
this.ActionDescription = actionDescription;
this.repo = DependencyResolver.Current.GetService<IRepository>();
}
void IActionFilter.OnActionExecuting(ActionExecutingContext filterContext)
{
if (this.IsLog)
{
MiniProfiler.Start(); this.OperatorName = filterContext.HttpContext.User.Identity.Name; this.ActionName = filterContext.ActionDescriptor.ActionName;
this.ControllerName = filterContext.ActionDescriptor.ControllerDescriptor.ControllerName;
IDictionary<string, object> dic = filterContext.ActionParameters;
var parameters = new System.Text.StringBuilder();
foreach (var item in dic)
{
parameters.Append(item.Key + "=" + Json.Encode(item.Value) + "|");
}
this.ActionParameters = parameters.ToString(); }
} void IActionFilter.OnActionExecuted(ActionExecutedContext context)
{
if (this.IsLog)
{
MiniProfiler.Stop();
string efSqlStr2Json = MiniProfiler.Current.Root.CustomTimingsJson; AuditLog log = new AuditLog();
log.AuditAccount = string.IsNullOrEmpty(this.OperatorName)?"(未登录用户)": this.OperatorName;
log.Action = this.ActionName;
log.ActionDescription = this.ActionDescription;
log.Controller = this.ControllerName;
log.Parameters = this.ActionParameters;
log.StartTime = this.AccessDate;
log.SqlQuery = efSqlStr2Json;
log.EndTime = DateTime.Now;
log.Result = true;
log.IP = IPHelper.GetRealIP(); repo.Insert<AuditLog>(log);
repo.SaveChanges();
}
} #region IExceptionFilter 成员
void IExceptionFilter.OnException(ExceptionContext context)
{
if (ConfigurationManager.AppSettings["IsDev"] == "true")
{
throw new Exception(context.Exception.Message, context.Exception);
} SystemLog slog = new SystemLog();
slog.Action = this.ActionName;
slog.Level = (int)SystemLogType.ERROR;
slog.LoginAccount = this.OperatorName;
slog.Message = BuildExceptionInfo(context);
slog.OccurTime = DateTime.Now; repo.Insert<SystemLog>(slog);
repo.SaveChanges(); JObject jsonResult = new JObject(); //返回的json数据
jsonResult.Add(new JProperty("Code", -));
jsonResult.Add(new JProperty("Msg", "系统发生异常,请查看内部日志"));
ContentResult cr = new ContentResult();
cr.Content = jsonResult.ToString();
cr.ContentType = "application/json";
context.Result = cr;
context.ExceptionHandled = true;
} private string BuildExceptionInfo(ExceptionContext context)
{
var sb = new StringBuilder();
var req = context.HttpContext.Request;
sb.AppendLine(String.Format("处理对“{0}”的“{1}”请求时发生了异常", req.RawUrl, req.HttpMethod));
sb.AppendLine("以下是参数的信息:");
this.AppendRequestLine(sb, req.QueryString);
this.AppendRequestLine(sb, req.Form);
sb.AppendLine("以下是异常的信息:");
sb.AppendLine(context.Exception.ToString());
//sb.AppendLine(context.Exception.StackTrace.ToString()); return sb.ToString();
} private void AppendRequestLine(StringBuilder sb, NameValueCollection coll)
{
for (int i = ; i < coll.Count; i++)
{
sb.AppendFormat("{0}: {1}", coll.Keys[i], coll[i]);
sb.AppendLine();
}
} #endregion }
}

3.以上的miniprofiler并不能 拦截到 sql语句查询,需要使用 minprofiler 封装的ado.net对象。

 /// <summary>
/// 执行自定义SQL(创建、更新、删除操作)
/// </summary>
/// <typeparam name="TEntity"></typeparam>
/// <param name="commandText"></param>
/// <param name="parameters"></param>
/// <returns></returns>
public async Task<int> ExecuteSqlCommandAsync(string commandText, params object[] parameters)
{
var connection1 = this.Database.Connection;//使用EF的sql连接对象。统一管理。
if (connection1 != null)
{
DbCommand command = new SqlCommand();
ProfiledDbCommand prcommand = new ProfiledDbCommand(command, connection1, MiniProfiler.Current);
prcommand.CommandType = CommandType.Text;
prcommand.CommandText = commandText;
prcommand.Parameters.AddRange(parameters);
prcommand.Connection = connection1; if (connection1.State == ConnectionState.Closed)
connection1.Open(); return await prcommand.ExecuteNonQueryAsync();
}
return ;
}
ProfiledDbCommand,
ProfiledDbConnection等对象都是MiniProfiler的对象。这样才能抓到 Sql语句。

4.由于miniprofiler是用来性能调优的,用来做审计日志记录(包括哪个用户最终生成的sql查询)看似并不合适,非常耗性能。
所以,我们并没有准备去使用它来获取Sql语句。 运用在
Application_BeginRequest和
Application_EndRequest
期间用EF6.0版本以上才有的 拦截器接口
DbCommandInterceptor
拦截的所有sql语句作为一次请求的sql查询语句 来作为尝试,不知道这样有啥劣势不?  希望有尝试过的 前辈 指点。
												

MiniProfiler使用点滴记录-2017年6月23日11:08:23的更多相关文章

  1. 读C#开发实战1200例子记录-2017年8月14日11:20:38获取汉字编码值

    try { char chr = textBox1.Text[0]; byte[] gb2312_bt = Encoding.GetEncoding("gb2312").GetBy ...

  2. 读C#开发实战1200例子记录-2017年8月14日10:03:55

    C# 语言基础应用,注释 "///"标记不仅仅可以为代码段添加说明,它还有一项更重要的工作,就是用于生成自动文档.自动文档一般用于描述项目,是项目更加清晰直观.在VisualStu ...

  3. 猖獗的假新闻:2017年1月1日起iOS的APP必须使用HTTPS

    一.假新闻如此猖獗 刚才一位老同事 打电话问:我们公司还是用的HTTP,马上就到2017年了,提交AppStore会被拒绝,怎么办? 公司里已经有很多人问过这个问题,回答一下: HTTP还是可以正常提 ...

  4. [转载]Ubuntu17.04(Zesty Zapus)路线图发布:2017年4月13日发布

    Canonical今天公布了Ubuntu 17.04(Zesty Zapus)操作系统的发布路线图,该版本于今年10月24日上线启动,toolchain已经上传且首个daily ISO镜像已经生成.面 ...

  5. 2017年1月5日 星期四 --出埃及记 Exodus 21:31

    2017年1月5日 星期四 --出埃及记 Exodus 21:31 This law also applies if the bull gores a son or daughter.牛无论触了人的儿 ...

  6. 2017年1月4日 星期三 --出埃及记 Exodus 21:30

    2017年1月4日 星期三 --出埃及记 Exodus 21:30 However, if payment is demanded of him, he may redeem his life by ...

  7. 2017年1月3日 星期二 --出埃及记 Exodus 21:29

    2017年1月3日 星期二 --出埃及记 Exodus 21:29 If, however, the bull has had the habit of goring and the owner ha ...

  8. 2017年1月2日 星期一 --出埃及记 Exodus 21:28

    2017年1月2日 星期一 --出埃及记 Exodus 21:28 "If a bull gores a man or a woman to death, the bull must be ...

  9. 2017年1月1日 星期日 --出埃及记 Exodus 21:27

    2017年1月1日 星期日 --出埃及记 Exodus 21:27 And if he knocks out the tooth of a manservant or maidservant, he ...

随机推荐

  1. String,StringBuilder,StringBuffer的对比测试

    public class TestString { private static final int COUNT = 10000000; public static void main(String ...

  2. JAVA虚拟机系列文章

    本系列文章主要记录自己在学习<深入理解Java虚拟机-JVM高级特性与最佳实践>的知识点总结,文章内容都是基于周志明所著书籍的总结. 1.Java内存区域与溢出 2.垃圾收集器与内存分配策 ...

  3. vim 和grep 正则表达式相似和区别

    正则表达式由两种基本字符类型组成:原义(正常)文本字符和元字符.元字符使正则表达式具有处理能力.所谓元字符就是指那些在正则表达式中具有特殊意义的专用字符,可以用来规定其前导字符(即位于元字符前面的字符 ...

  4. H5水果机,一个网络版的lao hu ji

    该游戏为h5小游戏,纯属娱乐,技术探讨,相关技术在文章结尾,欢迎探讨交流 花了几天时间开发了这款水果lao hu ji,更新了几个版本,还有不足的地方,由于时间有限暂时没有继续更新新版本 未完成的功能 ...

  5. JSONObjec序列化对象过滤为null的属性

    @Test public void test3() { PgwReqtBody3002 pgwReqtBody3002 = new PgwReqtBody3002(); pgwReqtBody3002 ...

  6. iOS学习之应用之间的操作(转发)

    首先要说的是每一个APP都可以设置一个自己独有的URL,APP应用之间的操作就是通过这个URL来实现的! 1.如何配置自己应用的URL? 关于自己的URL,作为资深的程序猿都会想到 Info.plis ...

  7. centos6.5 scala环境变量

    [root@m1 ~]# vi /etc/profile export SCALA_HOME=/usr/local/soft/scala-2.11.8export PATH=$PATH:$SCALA_ ...

  8. java基础之位运算

    java中常见的位运算符:&(逻辑与) |(逻辑或) ~(取反) ^(逻辑异或) >>(右移) <<(左移) >>>(无符号右移) &(逻辑与 ...

  9. javascript基础-闭包

    原理 函数里包含函数,即闭包. 包含函数的结果是,子函数会挟持父函数的活动对象.子函数在访问一个变量时,先读自身的活动对象,是否包含此变量,没有从父函数里找,还没有,去祖函数,层层回溯,直到windo ...

  10. VR全景智慧城市--2017年VR项目加盟将是一个机遇

    全景智慧城市项目是河南艺境空间文化传播有限公司自主开发的国内第一家商业全景平台, 旨在构建全景城市,实现智慧生活,让人们随时随地身临其境拥有全世界,享受快捷.真实.趣味.优质生活. 以VR虚拟现实技术 ...