从零开始编写自己的C#框架(17)——Web层后端首页

简介:

后端首页是管理员登陆后进入的第一个页面,主要是显示当前登陆用户信息、在线人数、菜单树列表、相关功能按键和系统介绍。让管理员能更方便的找到息想要的内容。

  根据不同系统的需要,首页会显示不同的内容,比如显示公司公告、公司新闻、内部短消息、个人事务、各种业务提醒......等各种内容,这些大家可以需要去进行呈现。

  

  先上代码

  Main.aspx

  View Code

  Main.aspx.cs

  View Code

 

  1、Main.aspx页面说明

  Main.aspx页面主要使用的是FineUI发布的空项目改造而来的,在这个基础上,顶部添加了当前用户的相关信息、在线人数,以及清除缓存、万年历和退出等按键。

  添加了<f:Timer ID="Timer1" Interval="60" Enabled="false" OnTick="Timer1_Tick" runat="server">定时器功能,它每60秒会运行一次,执行Timer1_Tick函数,检查当前用户是否已退出,检查当前用户帐号是否已在其他电脑或浏览器上登陆或给管理员踢出系统,更新顶部当前在线人数,更新用户最后在线时间(用于检查用户是否超时离线退出)

复制代码
 1      #region 定时器
 2         /// <summary>
 3         /// 定时执行方法
 4         /// </summary>
 5         /// <param name="sender"></param>
 6         /// <param name="e"></param>
 7         protected void Timer1_Tick(object sender, EventArgs e)
 8         {
 9             Timer1.Enabled = false;
10 
11             #region 检测当前用户是否退出
12             OnlineUsersBll.GetInstence().IsTimeOut();
13             #endregion
14 
15             #region 检测用户登录的有效性(是否被系统踢下线或管理员踢下线)
16             if (OnlineUsersBll.GetInstence().IsOffline(this))
17                 return;
18             #endregion
19 
20             #region 更新信息(在线人数,未读取的短消息)
21             if (HttpRuntime.Cache == null)
22             {
23                 txtOnlineUserCount.Text = "--";
24             }
25             else
26             {
27                 //更新当前在线用户数量
28                 txtOnlineUserCount.Text = OnlineUsersBll.GetInstence().GetUserOnlineCount() + "";
29             }
30             #endregion
31 
32             #region 修改用户最后在线时间
33 
34             //修改用户最后在线时间
35             OnlineUsersBll.GetInstence().UpdateTime();
36 
37             #endregion
38 
39             Timer1.Enabled = true;
40         }
41         #endregion
复制代码

 

  2、Main.aspx.cs文件父类

  它继承PageBase类,页面在加载的时间,就会自动调用父类的OnInit初始化函数,运行里面的程序,来检查当前用户是否退出,是否有当前页面的操作权限,设置放置在页面控件Id为toolBar中的各个按键是否有权限使用。并记录用户当前所在位置。

 

  3、添加页面按键事件

  对于FineUI的页面按键事件,共一两种,一种是服务器端事件OnClick,一种是客户端事件OnClientClick。

  添加了服务器端事件OnClick事件后,必须在cs文件中添加对应的事件函数,比如清空缓存按键(btnClearCache_Click)与安全退出按键(btnExit_Click)

复制代码
 1      #region 页面按键
 2 
 3         #region 清空缓存并重新加载
 4         /// <summary>
 5         /// 清空缓存并重新加载
 6         /// </summary>
 7         /// <param name="sender"></param>
 8         /// <param name="e"></param>
 9         protected void btnClearCache_Click(object sender, EventArgs e)
10         {
11             //清空全部后端缓存HttpRuntime.Cache(在线列表缓存除外)
12             CacheHelper.RemoveManagersAllCache();
13         }
14         #endregion
15 
16         #region 退出系统
17         /// <summary>
18         /// 退出系统
19         /// </summary>
20         /// <param name="sender"></param>
21         /// <param name="e"></param>
22         protected void btnExit_Click(object sender, EventArgs e)
23         {
24             LoginLogBll.GetInstence().UserExit();
25 
26             FineUI.Alert.ShowInTop("成功退出系统!", "安全退出", MessageBoxIcon.Information, "top.location='Login.aspx'");
27         }
28         #endregion
复制代码

  清空缓存按键主要功能:清除当前IIS应用程序池中除在线缓存以外的所有HttpRuntime.Cache缓存

  安全退出按键主要功能:删除当前登陆用户的所有缓存、Session与Cookies记录,并添加用户退出日志。

  点击退出后日志记录信息(LoginLog表):

  

 

  而客户端事件OnClientClick,只需要在页面中添加JS代码,它就会直接执行对应的JS函数,不与服务器端进行直接交互。

 

  当前除了以上添加按键事件外,还可以直接在代码中绑定控件事件方法(添加新选项卡还有其他一些方法,不过以这一种最为方便)

复制代码
 1         #region Page_Load
 2         protected void Page_Load(object sender, EventArgs e)
 3         {
 4             if (!IsPostBack)
 5             {
 6                 //添加万年历按键事件,在主窗口中添加新选项卡
 7                 btnCalendar.OnClientClick = mainTabStrip.GetAddTabReference("calendar_tab", "/WebManage/Help/wannianli.htm", "万年历", IconHelper.GetIconUrl(Icon.Calendar), true);
 8 
 9                 //加载信息
10                 LoadData();
11             }
12         }
13         #endregion    
复制代码

  以上代码主要是为万年历按键添加一个事件,点击按键后,在首页标签旁边新增一个选项卡,打开万年历页面。这些FineUI的范例官网上有,大家自行学习就可以了。

  

 

  4、展示用户信息

  这个比较简单,在LoadData函数中,直接从在线缓存中读取当前用户实体后,为页面顶部控件赋值就可以了。

  在这里简单的讲讲LoadData函数,这是父类的抽像函数(因为每个子类都必须将它实现,所以将它从虚函数改为抽像函数),在每个子类中都必须要重写它,它的主要功能是加载数据,列表页面主要加载的是列表中需要显示的记录,而编辑页面加载的是各个页面的实体,将它们与页面控件进行绑定并显示出来。实现了该函数后,它将会被父类中的其他各种函数引用,比如刷新、查询、翻页、保存排序、自动排序、删除、关闭子窗口......等函数执行完后会调用它来重新加载数据,刷新页面显示内容,具体大家可以查看PageBase.cs类,看看有那些函数引用了LoadData函数就知道了。

 

  5、绑定菜单栏树列表

  首先将所有可以显示的菜单全部读取出来

  下面是LoadData函数中的一段代码

复制代码
 1             #region 菜单栏数据绑定
 2             //获取用户页面操作权限
 3             _pagePower = OnlineUsersBll.GetInstence().GetPagePower();
 4 
 5 
 6             //创建查询条件
 7             var wheres = new List<ConditionFun.SqlqueryCondition>();
 8             //条件:只查询出需要显示的菜单
 9             wheres.Add(new ConditionFun.SqlqueryCondition(ConstraintType.And, MenuInfoTable.IsDisplay, Comparison.Equals, 1));
10             //进行查询,获取DataTable
11             var dt = MenuInfoBll.GetInstence().GetDataTable(false, 0, null, 0, 0, wheres);
12             //绑定树列表
13             BandingTree(dt);
14 
15             #endregion
复制代码

  ConditionFun.SqlqueryCondition是封装好的查询条件类。

  第一个参数为查询表达式,即当前条件与前一条件使用的表达式是And还是Or;

  第二个参数是想要查询的列表名称,这里我们使用的是表名+Table.列名的方式调用,这样操作的话可以使我们的代码去除硬编码,好处是当我们万一修改了数据库字段名称后,重新生成相关的模板并按F6重新编译代码时,就会直接报出所有未同步修改的代码错误位置出来,让我们能快速定位并修改掉它,而硬编码(指的是直接使用类似"IsDisplay"这种字段书写格式的代码)则不会报错,代码量多时我们将很难找出问题,直接程序执行到对应位置时才会抛出异常。

  第三个参数是条件值表达式,表示当前列与值的关系,比如:等于、大于、小于、in、not in、like......等;

  第四个参数是条件值

  在这里要同大家说明的是,SubSonic3.0对于括号支持的不是很多,只支持单层括号,嵌套括号时将会出错,为了避免这种问题,建议多括号做为条件值查询时,请使用Linq表达式来查询(Lambd表达式),或者存储过程。具体加括号后的使用方法在后面章节会详细的进行说明。

  MenuInfoBll.GetInstence().GetDataTable()函数是我们逻辑层生成好的模板函数,我们直接调用就可以了。(我们后端开发对于数据的增、删、查、改等操作函数几乎都已经生成好了,直接调用就可以)

  通过执行BandingTree函数与AddChildrenNode函数,将菜单树列表创建后绑定<f:Tree runat="server" ShowBorder="false" ShowHeader="false" EnableArrows="true" EnableLines="true" ID="leftMenuTree"></f:Tree>控件

  下面通过向MenuInfo表添加一些菜单记录来演示我们首页中的树列表显示效果

  View Code

 

  6、小结

  登陆页、父类与后端首页,是本系统三个最基本的组成零部件,完成了这三个部件后,接下来就是体验如何来进行快速开发的成果了。后面章节发表的内容,主要是针对框架中已生成函数或一些特殊功能(函数)的调用方法讲解,用实例来讲述这些功能的使用方法。

 

 

  点击下载:

本框架不内置 ExtJS 库,请自行下载ExtJS 库后手工添加到Solution.Web.Managers项目的根目录中(如下图):http://fineui.com/bbs/forum.php?mod=viewthread&tid=3218

 



    本文转自 AllEmpty 博客园博客,原文链接:http://www.cnblogs.com/EmptyFS/p/3791945.html,如需转载请自行联系原作者



相关文章
|
4天前
|
前端开发 JavaScript 关系型数据库
从前端到后端:构建现代化Web应用的技术探索
在当今互联网时代,Web应用的开发已成为了各行各业不可或缺的一部分。从前端到后端,这篇文章将带你深入探索如何构建现代化的Web应用。我们将介绍多种技术,包括前端开发、后端开发以及各种编程语言(如Java、Python、C、PHP、Go)和数据库,帮助你了解如何利用这些技术构建出高效、安全和可扩展的Web应用。
|
5天前
|
数据可视化 网络协议 C#
C#/.NET/.NET Core优秀项目和框架2024年3月简报
公众号每月定期推广和分享的C#/.NET/.NET Core优秀项目和框架(每周至少会推荐两个优秀的项目和框架当然节假日除外),公众号推文中有项目和框架的介绍、功能特点、使用方式以及部分功能截图等(打不开或者打开GitHub很慢的同学可以优先查看公众号推文,文末一定会附带项目和框架源码地址)。注意:排名不分先后,都是十分优秀的开源项目和框架,每周定期更新分享(欢迎关注公众号:追逐时光者,第一时间获取每周精选分享资讯🔔)。
|
19天前
|
API 数据库 数据安全/隐私保护
利用Django框架构建高效后端API服务
本文将介绍如何利用Django框架构建高效的后端API服务。通过深入分析Django框架的特性和优势,结合实际案例,探讨了如何利用Django提供的强大功能来构建高性能、可扩展的后端服务。同时,还对Django框架在后端开发中的一些常见问题进行了解决方案的探讨,并提出了一些建设性的建议。
36 3
|
1月前
|
开发工具 git
web后端-IDEA的Git操作
web后端-IDEA的Git操作
|
1月前
|
缓存 关系型数据库 API
后端开发:构建高效、可扩展的Web应用程序的关键
后端开发:构建高效、可扩展的Web应用程序的关键
15 0
|
1月前
web后端-IIS-web发布
web后端-IIS-web发布
|
1月前
|
应用服务中间件 Apache nginx
web后端-web服务器对比
web后端-web服务器对比
|
1月前
|
应用服务中间件
web后端-EasyWeb-web发布
web后端-EasyWeb-web发布
|
1月前
|
监控
web后端-最好用的扒站仿站工具(网页克隆网页复制)
web后端-最好用的扒站仿站工具(网页克隆网页复制)
|
1月前
|
机器学习/深度学习 XML JSON
web后端-java-httpClient
web后端-java-httpClient