MVC 实现计算页面执行时间
使用 ActionFilterAttribute 来实现:
public class PerformanceActionAttribute:ActionFilterAttribute
{
public string Message { get; set; } public override void OnActionExecuting(ActionExecutingContext filterContext)
{
//在Action执行前执行 GetTimer(filterContext, "action").Start(); base.OnActionExecuting(filterContext);
} public override void OnActionExecuted(ActionExecutedContext filterContext)
{
//在Action执行之后执行
var actionTimer = GetTimer(filterContext, "action");
//GetTimer(filterContext, "action").Stop();
actionTimer.Stop();
base.OnActionExecuted(filterContext);
string extime = "页面执行耗时" + actionTimer.ElapsedMilliseconds+"毫秒";
filterContext.HttpContext.Response.Headers.Add("extime",extime);
//在这里显示给用户的时间只是action的执行时间,如果在view中有执行调用代码的部分,则时间不会
//记录在内,所以这里的时间不是很准,但是这个时间可以很自由的被view中的代码调用显示,使得界面可以按照
//自己的意愿进行显示
} public override void OnResultExecuting(ResultExecutingContext filterContext)
{
GetTimer(filterContext, "render").Start(); base.OnResultExecuting(filterContext);
} public override void OnResultExecuted(ResultExecutedContext filterContext)
{
//在Result执行之后
//这里使用response.write输出只能是输出到documnet的最后部分,不能按照想法显示到指定的随意位置
//所以这里隐藏显示了。
//这这部分使用response.Headers是无效的,因为当执行这部分内容的时候,view已经渲染完了,在这添加到Header
//中的值,无法在页面获得
var renderTimer = GetTimer(filterContext, "render");
renderTimer.Stop(); var actionTimer = GetTimer(filterContext, "action");
var response = filterContext.HttpContext.Response; if (response.ContentType == "text/html")
{
response.Write(
String.Format(
"<p id='pidtimeelapse' style='display:none;'>Action '{0} :: {1}', Execute: {2}ms, Render: {3}ms.</p>",
filterContext.RouteData.Values["controller"],
filterContext.RouteData.Values["action"],
actionTimer.ElapsedMilliseconds,
renderTimer.ElapsedMilliseconds
)
); } base.OnResultExecuted(filterContext);
} private Stopwatch GetTimer(ControllerContext context, string name)
{
string key = "__timer__" + name;
if (context.HttpContext.Items.Contains(key))
{
return (Stopwatch)context.HttpContext.Items[key];
} var result = new Stopwatch();
context.HttpContext.Items[key] = result;
return result;
}
}
在action 处使用 见第一行
[PerformanceAction]
public ActionResult Index(string type="默认",int pageIndex=)
{
string orderType = type;
int pageSize = pageSizeCom;
int total = ;
List<vArticleMain> list = artBLL.GetArticleByPage(pageIndex, pageSize, orderType, out total);
ViewBag.list = list; //分页信息 ViewBag.pageIndex = pageIndex;
ViewBag.pageCount = total;
ViewBag.type = type; return View();
}
在view 中显示 可以在指定位置引用
<div class="row col-md-12">
@Response.Headers.Get("extime")
</div>
还有一种是使用 httpmodule的方法,使用该方法不用在每个action上加特性了
地址:http://haacked.com/archive/2008/07/02/httpmodule-for-timing-requests.aspx/
但是在使用该方法调试的时候,出现一个进程中有多个线程的情况,该方法多次执行。而时间编程是单线程的,没有定义多线程,不知道为什么会出现多线程情况。
所以没有使用该方法。(该方法得到的时间比filter的方法得到的时间要更准确)
filter方法参考链接:http://bradwilson.typepad.com/blog/2010/07/aspnet-mvc-filters-and-statefulness.html
http://www.sharejs.com/codes/csharp/6235
http://blog.csdn.net/keepitshortandsimple/article/details/7357954
第二天想到新的解决办法,思路就是:OnResultExecuted 中最后输出的代码虽然不在服务器端的view中用response取得,只能输出到页面的最后部分,
但是当信息传输到浏览器上的时候,可以用jquery 来取得输出的内容,然后显示到指定的位置。OnResultExecuted 方法只是在view页面在服务器端渲染完之后执行,
不是在浏览器上显示完之后执行,所以可以在浏览器上取得在OnResultExecuted 阶段输出的内容。
attribute的代码 :在 OnActionExecuted 阶段不再输出内容
public class PerformanceActionAttribute:ActionFilterAttribute
{
public string Message { get; set; } public override void OnActionExecuting(ActionExecutingContext filterContext)
{
//在Action执行前执行 GetTimer(filterContext, "action").Start(); base.OnActionExecuting(filterContext);
} public override void OnActionExecuted(ActionExecutedContext filterContext)
{
//在Action执行之后执行
//var actionTimer = GetTimer(filterContext, "action");
GetTimer(filterContext, "action").Stop();
//actionTimer.Stop();
base.OnActionExecuted(filterContext);
//string extime = "页面执行耗时" + actionTimer.ElapsedMilliseconds+"毫秒";
//filterContext.HttpContext.Response.Headers.Add("extime",extime); //在这里显示给用户的时间只是action的执行时间,如果在view中有执行调用代码的部分,则时间不会
//记录在内,所以这里的时间不是很准,但是这个时间可以很自由的被view中的代码调用显示,使得界面可以按照
//自己的意愿进行显示 //想出新的办法了,所以这里注释掉,用下边的总时间
} public override void OnResultExecuting(ResultExecutingContext filterContext)
{
GetTimer(filterContext, "render").Start(); base.OnResultExecuting(filterContext);
} public override void OnResultExecuted(ResultExecutedContext filterContext)
{
//在Result执行之后
//这里使用response.write输出只能是输出到documnet的最后部分,不能按照想法显示到指定的随意位置
//所以这里隐藏显示了。
//这这部分使用response.Headers是无效的,因为当执行这部分内容的时候,view已经渲染完了,在这添加到Header
//中的值,无法在页面获得 //第二天想出新的方法来解决
//如下所以,输出到页面的内容放到固定标签中,有ID,然后再页面上用js来取得对应的内容,然后相加,显示到指定的位置
var renderTimer = GetTimer(filterContext, "render");
renderTimer.Stop(); var actionTimer = GetTimer(filterContext, "action");
var response = filterContext.HttpContext.Response; if (response.ContentType == "text/html")
{
response.Write(
String.Format(
"<p id='disAction' style='display:block;'>Action '{0} :: {1}' <span id='disexecute'>{2}</span><span id='disrender'>{3}</span></p>",
filterContext.RouteData.Values["controller"],
filterContext.RouteData.Values["action"],
actionTimer.ElapsedMilliseconds,
renderTimer.ElapsedMilliseconds
)
); } base.OnResultExecuted(filterContext);
} private Stopwatch GetTimer(ControllerContext context, string name)
{
string key = "__timer__" + name;
if (context.HttpContext.Items.Contains(key))
{
return (Stopwatch)context.HttpContext.Items[key];
} var result = new Stopwatch();
context.HttpContext.Items[key] = result;
return result;
}
}
在controller中的内容不变,
在view中的内容:
<div id="pagetime" class="row col-md-12"> </div>
jquery
$(function () {
var disexecute = $("#disexecute").html();
var disrender = $("#disrender").html();
var ht = "页面执行耗时" + (parseInt(disexecute) + parseInt(disrender)) + "毫秒";
$("#pagetime").html(ht);
});
这样就比较完美了
MVC 实现计算页面执行时间的更多相关文章
- PHP 计算页面执行时间
PHP 计算页面执行时间 < ?php class runtime { var $StartTime = 0; var $StopTime = 0; function get_microtime ...
- 一:理解ASP.NET的运行机制(例:通过HttpModule来计算页面执行时间)
一:简要介绍一下asp.net的执行步骤 1.IIS接收到客户请求 2. IIS把请求交给aspnet_isapi.dll处理 3.(如果是第一次运行程序)装载bin目录中的dll 4.(如果是第一次 ...
- 在Asp.Net MVC中实现计算页面执行时间及简单流量统计
引用www.rsion.com.dll进您的asp.net MVC项目本人不才,源代码中有详细说明,查看demo修改HomeController public class HomeController ...
- 三行代码实现.NET MVC统计显示页面的执行时间 超简单的实现方法 分析页面执行效率
三行代码实现.NET MVC统计显示页面的执行时间 超简单的实现方法 分析页面执行效率 博客页脚处添加了页面执行时间统计显示,如下图所示,也可以直接查看网页页脚处. 实现方法非常简单,只需三行代 ...
- PHP获取页面执行时间的方法
一些循环代码,有时候要知道页面执行的时间,可以添加以下几行代码到页面头部和尾部: 头部: <?php $stime=microtime(true); 尾部: $etime=microtime(t ...
- PHP获取页面执行时间的方法(推荐)
一些循环代码,有时候要知道页面执行的时间,可以添加以下几行代码到页面头部和尾部: 头部:$stime=microtime(true); 尾部: $etime=microtime(true);//获取程 ...
- 【问题】Asp.net MVC 的cshtml页面中调用JS方法传递字符串变量参数
[问题]Asp.net MVC 的cshtml页面中调用JS方法传递字符串变量参数. [解决]直接对变量加引号,如: <button onclick="deleteProduct('@ ...
- 七天学会ASP.NET MVC (五)——Layout页面使用和用户角色管理
系列文章 七天学会ASP.NET MVC (一)——深入理解ASP.NET MVC 七天学会ASP.NET MVC (二)——ASP.NET MVC 数据传递 七天学会ASP.NET MVC (三)— ...
- 学习笔记:Asp.Net MVC更新部分页面
Asp.Net MVC 更新部分页面 设想我们有一篇文章下面的提交评论时如何只刷新评论内容部分, 方法一,利用ajax通过js代码实现. 方法二,利用Ajax.BeginForm()+部分视图实现. ...
随机推荐
- Educational Codeforces Round 5 B
Problem B:http://codeforces.com/contest/616/problem/B B. Dinner with Emma 题意:一对夫妻要去餐厅吃晚饭,Emma 想去最豪华( ...
- mac忘记密码的解决办法
开机, 启动时按"cmd+S".这时,你会进入Single User Model,出现像DOS一样的提示符 #root>.请在#root>下 输入 (注意空格, 大小写 ...
- 让wordpress分类和标签的描述支持HTML代码
默认 WordPress 后台分类和标签的编辑页面,分类和标签的描述是不支持 HTML 代码的,我们可以通过在当前主题的 functions.php 文件添加如下代码让分类和标签的描述支持 HTML ...
- fiddler插件开发step by step 1
Fiddler 是优秀的抓包工具,有着众多的优秀插件.Fiddler 软件是由C#语言开发的,运行在.net Framework 框架之上,所以我们也可以使用vs来开发自己的Fiddler插件,下面就 ...
- 阿里云 EDAS-HSF 用户指南
阿里云 EDAS-HSF 用户指南 针对 EDAS v2.3.0©Alibaba EDAS 项目组2015/8/19 1 前言本文档旨在描述阿里云 EDAS 产品中应用服务化模块的基本概念,以及如何使 ...
- codeforces #310 div1 C
操作无论是U还是L,都会使原图形分裂成两个图形,且两个图形的操作互不影响 我们又发现由于操作点只可能在下斜线上,如果将操作按x排序 那么无论是U还是L,都会将操作序列完整分割成两半,且两个操作序列互不 ...
- Qt: qobject_cast<QPushButton*>(sender()) 简化信号与槽的编写
当你觉得写代码是一件重复性极高的工作时,这时你就应该考虑换个方式来实现了. 提高代码效率,减少代码量. 代码片: void Widget::onClicked() { QPushButton* but ...
- ArcGIS学习记录—union、merge及append的区别
原文地址: ArcGIS问题:union.merge及append的主要区别[转] - Silent Dawn的日志 - 网易博客 http://gisman.blog.163.com/blog/st ...
- Android 监听EditView中的文本改变事件
android中的编辑框EditText也比较常用,那比如在搜索框中,没输入一个字,下面的搜索列表就显示有包含输入关键字的选项,这个输入监听怎么实现的呢? 我们可以建一个例子,效果图如下: 我们可以监 ...
- 列出man手册所有函数的方法
locate /man7/|sed -r 's#.*/([^/]+).7.gz$#\1#' locate /man7/ | xargs basename -a -s '.7.gz' apropos - ...