asp.net MVC 统计在线人数功能实现
今天开发一个设计一个统计在线人数的统计。实现方式是在MVC 中,用户次执行一个Action请求完成后,向数据表中插入一条用户心跳记录,统计在线人数则是根据该记录,30分钟内有记录的用户则为在线状态。
首先设计表心跳记录表结构MOdel

接下来添加 CheckACAttribute 类继承 ActionFilterAttribute基类,并在FilterConfig类中注册。
public class FilterConfig
{
public static void RegisterGlobalFilters(GlobalFilterCollection filters)
{
filters.Add(new HandleErrorAttribute());
filters.Add(new ASSFramework.Web.Common.CheckACAttribute());
}
}
CheckACAttribute类的拦截器方法实现如下
public override void OnActionExecuted(ActionExecutedContext filterContext) {
if (isInsertOpenLog == true) { //判断是否写入心跳记录
//每一个action 执行后记录一下操作日志,用于统计用户在线。
ASSFramework.Services.BLL.sysOpenLogBLL bll = new ASSFramework.Services.BLL.sysOpenLogBLL();
BaseController baseController = (BaseController)filterContext.Controller;
sysOpenLog model = new sysOpenLog();
model.userID = baseController.GetSysUser().userID; //获取用户ID
model.userNameCn = baseController.GetSysUser().userNameCn; //用户名称
model.createdDate = DateTime.Now;
model.flag = 1;
bll.Insert(model);
}
base.OnActionExecuted(filterContext);
}
业务逻辑层
public class sysOpenLogBLL {
DAL.sysOpenLogDAL dal = new DAL.sysOpenLogDAL();
/// <summary>
/// 统计在线人数
/// </summary>
/// <returns></returns>
public IList<Hashtable> GetOnLinelList() {
return dal.GetOnLinelList();
}
}
数据访问层,数据访问使用到的是IBatisNet框架,该框架轻小灵活,第一次使用就深深的喜欢上了。
public class sysOpenLogDAL {
/// <summary>
/// 统计在线人数
/// </summary>
/// <returns></returns>
public IList<Hashtable> GetOnLinelList() {
string stmtId = "sysOpenLog.GetOnLinelList";
return ASSMapper.Instance().QueryForList<Hashtable>(stmtId, "");
}
表映射xml文件如下
<statements>
<!--统计在线人数,近半个小时有活动的用户-->
<select id="GetOnLinelList" parameterClass="map" resultClass="Hashtable">
select userID,userNameCn,MAX(createdDate)
from sysOpenLog
group by userID,userNameCn
having MAX(createdDate) >= DATEADD(MINUTE,-30,GETDATE())
</select>
<!--添加-->
<insert id="Insert" parameterClass="sysOpenLog" resultClass="Int32">
Insert into sysOpenLog( userID, userNameCn, createdDate, flag )values( #userID#, #userNameCn#, #createdDate#, #flag# ) SELECT @@IDENTITY
</insert>
</statements>
基础数据通过action 请求后写入心跳记录表,接下来就要展示出来在线人数信息
在控制器中添加 Index()
public ActionResult Index()
{
ASSFramework.Services.BLL.sysOpenLogBLL bll = new Services.BLL.sysOpenLogBLL();
IList<Hashtable> model = bll.GetOnLinelList();
return View(model);
}
添加Idex视图页面
@{
Layout = "~/Views/Shared/_Layout.cshtml";
}
@using System.Collections;
@using ASSFramework.Models;
@model IList<Hashtable>
<!--导航-->
@Html.place("首页;用户管理;在线统计")
<div class="formbody">
<div class="formtitle"><span>在线人数</span></div>
<div class="toolsli">
<ul class="toollist">
@foreach (var item in Model) {
<li><a><img src="~/Content/theme/images/i07.png" /></a><h2>@item["userNameCn"] </h2></li>
}
</ul>
</div>
</div>
最终显示结果如下

这次只贴出来了大致的实现思路和简单的代码贴图。
统计在线人数的功能基本实现了,但是这时要考虑到这心跳记录表如果用户量多,而且操作频繁的话,数据量会越来越大,这里我们只需要统计半小时以内的用户活动记录,所以在sql server 数据库中添加一个作业,定时删除垃圾数据。
asp.net MVC 统计在线人数功能实现的更多相关文章
- PHP实现统计在线人数功能示例
本文实例讲述了PHP实现统计在线人数的方法.分享给大家供大家参考,具体如下: 我记得ASP里面统计在线人数用application 这个对象就可以了.PHP怎么设计? PHP对session对象的封装 ...
- PHP 实现精确统计在线人数功能
有需要学习交流的友人请加入交流群的咱们一起,有问题一起交流,一起进步!前提是你是学技术的.感谢阅读! 点此加入该群jq.qq.com PHP对session对象的封装的很好,根据HTTP协议,每个范 ...
- kindeditor-4.1.10 结合 Asp.Net MVC 添加图片功能
KindEditor是一套开源的HTML可视化编辑器,现在我要结合Asp.Net MVC4 上传图片功能,做相应的配置和修改, 其实网上也有人写过类似的文章了,我写出来是以防以后使用的时候出现这样的问 ...
- ASP.NET MVC 3:缓存功能的设计问题
今天这一篇文章我来谈一谈在MVC 3项目中的缓存功能,以及针对缓存的一些设计上的考量,给大家参考参考. 为什么需要讨论缓存?缓存是一个中大型系统所必须考虑的问题.为了避免每次请求都去访问后台的资源(例 ...
- asp.net mvc 简单搜索功能
View中代码: <input type="text" class="searchText" id="searchText"/> ...
- 转 ---- Asp.net mvc项目分页功能
1.定义一个分页用的Page<T>类 1 /* 使用示例: 2 var pager = new Pager<Article>( 3 this.ControllerContext ...
- Asp.net mvc项目分页功能
1.定义一个分页用的Page<T>类 /* 使用示例: var pager = new Pager<Article>( this.ControllerContext, //上下 ...
- Application 统计在线人数
MVC 统计在线人数: protected void Application_Start() { Application[; AreaRegistration.RegisterAllAreas(); ...
- ASP.NET没有魔法——ASP.NET MVC 过滤器(Filter)
上一篇文章介绍了使用Authorize特性实现了ASP.NET MVC中针对Controller或者Action的授权功能,实际上这个特性是MVC功能的一部分,被称为过滤器(Filter),它是一种面 ...
随机推荐
- python的线程锁
1.先看一个例子,一个进程可以起多个线程,多个线程都共享这个线程的内存 import threading import time num = 100 thread_lock = threading.L ...
- struts框架中OGNL表达式的使用之jsp页面获取action中的属性值
在jsp页面中获取action中的值: 1.写一个action类OgnlAction类: 需要注意的地方: 如果在aciton中直接使用ognl表达式,将值存储的值栈中,是不能通过跳转将值传到jsp页 ...
- 改变父元素的透明度,不影响子元素的透明度—css
1.如果我们给父元素添加opacity:0.4后,子元素的red颜色也变成了0.4的透明度, 例子如下: <!DOCTYPE html> <html> <head> ...
- PHP-GTK的demo在windows下运行出现的问题
I am trying to use Firebird 2.5.2.26539 with wamp,When i enable the extensions of firebird in php: - ...
- 嵌入式的SQL程序设计
嵌入式的SQL程序设计 sql语句大全之嵌入式SQL 2017-01-18 16:00 来源:未知 嵌入式SQL 为了更好的理解嵌入式SQL,本节利用一个具体例子来说明.嵌入式SQL允许程序连接数 ...
- BZOJ2424 [HAOI2010]订货 - 费用流
题解 (非常裸的费用流 题意有一点表明不清: 该月卖出的商品可以不用算进仓库里面. 然后套上费用流模板 代码 #include<cstring> #include<queue> ...
- js父子窗口传值以及当前页面在js前台如何获得url参数
1.首先是父页面用window.open打开窗口 <%@ Page Language="C#" AutoEventWireup="true" CodeBe ...
- 【JS】点击页面判断是否安装app并打开,否则跳转下载的方法
应用场景 App产品在运营推广上有一个需求,就是要求可以让用户在访问我们的推广网页时,就可以判断出这个用户手机上是否安装了我们的App,如果安装了则可以直接在网页上打开,否则就引导用户前往下载.从而形 ...
- 2018.09.23 bzoj1076: [SCOI2008]奖励关(期望+状压dp)
传送门 一道神奇的期望状压dp. 用f[i][j]f[i][j]f[i][j]表示目前在第i轮已选取物品状态为j,从现在到第k轮能得到的最大贡献. 如果我们从前向后推有可能会遇到不合法的情况. 所以我 ...
- c#中关于变量声明那么点事
class MyVar { /* * 基于安全的考虑,c#变量的初始化有一定的要求 * 1.所有的局部变量在被显示的初始化之前,都会被编译器当作未初始化,然后抛出编译期出错; * 2.所有的字段级变量 ...