【自然框架】 页面里的父类——把共用的东东都交给父类,让子类专注于其他。

【类图】

【命名空间】——————————————————【文件截图】

可能您会问,不就是弄个父类吗,怎么又是这么复杂呢?这个嘛,听我慢慢道来。

(类图里面Tree、Main1、DataDelete1、DataForm1、DataList1不是父类,而是共用页面)

      这个是依据自然框架的特点来设置的,目的就是把共用的代码都放到父类里面,减轻子类的代码量。就是最大限度的避免冗余代码,就是说相同的代码只出现在一处!

      如果只设置一个父类,不能满足不同的需求,所以就根据不同的需求,设置了多级的父类。

1、 BasePage 。 public class BasePage : System.Web.UI.Page {}       这个就是为了定义数据访问函数库的实例,用于访问数据库。在OnUnload的时候进行一下收尾工作。       我的想法就是,一个用户在一次访问周期里,只使用一个访问数据库的实例。特殊情况除外。因为我自己写的数据访问函数库不是静态函数的,使用前必须先new一下,而每次用的时候都要new比较麻烦,所以就放在父类里面了。

2、 PagePermission。 public class PagePermission : BasePage       这里是做权限验证用的,首先要验证用户是否登录,如果没有登录那还谈什么权限呀。然后是两个函数,一个是验证当前用户是否可以访问指定的FunctionID(功能节点ID),另一个是验证当前用户是否可以访问指定的ButtonID(功能按钮ID)。这两个函数并不是在这里被调用,而是给子类准备的。 3、  PageURL。public class PageURL : PagePermission       这里面要处理URL传递过来的参数。在自然框架里面大部分页面都要传递FunctionID,表单页面都要传递ButtonID、DataID,一些页面还需要传递ForeignID(外键)、DepartmentID(部门ID)。URL传递过来的,那么首先就要先接收下来,然后要进行验证以避免SQL注入攻击。 这些工作就要在这里完成了。

(再往下就有分支了) 4、  BasePageList。 public partial class BasePageList : PageURL       数据列表页的基类。这里要定义分页控件、查询控件、查询按钮、按钮组控件、数据显示控件,在OnInit里面调用父类函数验证是否有权限访问,然后给这些控件的属性赋值(依据元数据来赋值)、设置关联关系。 5、  BasePageForm。public partial class BasePageForm : PageURL        表单页面的基类。这里要定义表单控件、保存按钮等。       在OnInit里面首先验证DataID,再调用父类函数验证是否有权限访问,再验证是否可以访问指定的记录(DataID),然后给这些控件的属性赋值(依据元数据来赋值)、设置关联关系。给保存按钮定义事件。       在OnLoad里面设置表单的状态:添加、修改、查看等。 6、  BasePageDelete。public class BasePageDelete : PageURL       删除数据的基类。       在OnInit里面首先验证DataID,再调用父类函数验证是否有权限访问,再验证是否可以访问指定的记录(DataID)。

下面介绍公用页面 1、 DataList1、DataList1.aspx。public partial class DataList1 : Base.BasePageList         数据列表的共用页面。由于自然框架采用了“自定义控件+元数据”的方式,所以90%以上的列表页面都可以由这个页面来实现,上次视频演示的Demo里面,角色的列表、新闻维护、新闻分类的列表都是 DataList1.aspx。 由于大部分代码都放在了基类里面,所以这里主要是做页面布局,.aspx.cs里面只需要写几行代码即可。

2、  DataForm1、DataForm1.aspx。public partial class DataForm1 : Base.BasePageForm        表单的共用页面。由于自然框架采用了“自定义控件+元数据”的方式,所以20%以上的表单页面都可以由这个页面来实现,上次视频演示的Demo里面,添加新闻、添加分类的表单都是DataForm1.aspx。

3、 DataDelete1、DataDelete1.aspx。public partial class DataDelete1 : Base.BasePageDelete          删除数据的共用页面。删除数据是一件很复杂的事情,一个页面是不可能搞定的,这个页面只是实现最最简单的删除的功能,其他复杂的就需要单独写代码实现了。

总结:URL参数的验证、权限的验证、访问记录的验证、控件属性赋值等,都交给父类去做,子类就可以不用去考虑权限的问题,专心致志的处理好自己的业务逻辑了。这样程序员就可以说:我是写代码的(实现具体功能),权限管我p事。

      对了,还有一点忘记说了,这是一个独立的、单独的项目,他编译后会生成 Nature.BaseUI.dll 文件,然后在做新的的项目的时候可以引用这个dll文件,然后在把其他的.aspx文件拷贝到项目的指定的文件夹里面。注意只是拷贝文件,不用添加到新的项目里。 附:BasePageList  的代码。如果您感兴趣的话,可以到这里下载全部代码。http://www.cnblogs.com/jyk/archive/2009/09/09/1563269.html

namespace Nature.UI.Base
{
    /**//// <summary>
    /// 列表页面的基类
    /// 这个算不算模板模式呢?
    /// </summary>
    public partial class BasePageList : PageURL
    {
        定义共用的控件,以便于统一控制#region 定义共用的控件,以便于统一控制
        /**//// <summary>
        /// 分页用的控件
        /// </summary>
        public QuickPager ctl_CommonPager;
        /**//// <summary>
        /// 显示数据用的控件
        /// </summary>
        public MyGrid ctl_CommonGrid;
        /**//// <summary>
        /// 查询控件
        /// </summary>
        public MyFind ctl_CommonFind;
        /**//// <summary>
        /// 查询按钮
        /// </summary>
        public Button Btn_Search;
        /**//// <summary>
        /// 按钮组,功能(操作)按钮
        /// </summary>
        public OperationButtonBar ctl_CommonButtonBar;
        #endregion
        /**//// <summary>
        /// 在 OnInit 事件里面设置各个自定义控件的属性和关联
        /// </summary>
        /// <param name="e"></param>
        protected override void OnInit(EventArgs e)
        {
            base.OnInit(e);
            //调用父类函数,验证是否有权限访问。
            CheckFunctionID(this.FunctionID);
            //设置分页控件的属性和事件
            SetQuickPagerInfo();
            //设置数据表格的属性
            SetGridInfo();
            //设置查询控件的属性
            SetFindControlInfo();
            //设置操作按钮的属性
            SetButtonBarInfo();
        }
    }
}

验证权限的两个函数

/**//// <summary>
        /// 验证当前用户是否可以访问指定的功能节点
        /// </summary>
        /// <param name="functionID">要验证的节点</param>
        public void CheckFunctionID(string functionID)
        {
             //判断当前用户是否有权限访问该网页,
            string tmpFunctionIDs = "," + this.MyUser.FunctionIDs + ",";
            functionID = "," + functionID + ",";
            if (tmpFunctionIDs.IndexOf(functionID) >= 0)
            {
                //有权限
            }
            else
            {
                //没有权限
                Response.Write("没有权限");
                Response.Redirect("/noPermission.aspx");
                Response.End();
            }
        }
 
        /**//// <summary>
        /// 验证当前用户是否可以使用指定的按钮打开的页面
        /// </summary>
        /// <param name="functionID">要验证的节点</param>
        /// <param name="buttonID">要验证的按钮ID</param>
        public void CheckButtonID(string functionID, string buttonID)
        {
             //判断当前用户是否可以使用指定的按钮打开的页面,
            //获取当前用户可以使用的按钮
            string buttonIDs = MyUser.GetUserButtonID(functionID);
            buttonIDs = "," + buttonIDs + ",";
            buttonID = "," + buttonID + ",";
            if (buttonIDs.IndexOf(buttonID) >= 0)
            {
                //有权限
            }
            else
            {
                //没有权限
                Response.Write("没有权限");
                Response.Redirect("/noPermission.aspx");
                Response.End();
            }
        }

========================= =希望我的想法,能够给您带来一点帮助!= =大家一起研究、讨论,共同提高、发财!= =========================

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Aloys的开发之路

Linux乱码问题解决方案

linux系统中文件名内容为urf8编码, windows系统中文件名默认为gbk编码, 多数文档使用gbk编码,系统采用utf8编码 无中文输入法导致的乱码 ...

3938
来自专栏大学生计算机视觉学习DeepLearning

VS下如何建立一个新的MFC程序 网络编程 课设 基于C++ MFC 连接数据库 小应用 小项目浅析展示

2953
来自专栏小特工作室

Navi.Soft31.开发工具(含下载地址)

1系统简介 1.1功能简述 在软件开发过程中,我们需要经常对字符串、文件、数据库操作。有时需要浏览Json格式串,有时需要浏览Xml格式串,有时需要读取txt或...

2369
来自专栏陈本布衣

treeview插件使用:根据子节点选中父节点

  鄙人公司没有专门的前端,所以项目开发中都是前后端一起抡。最近用bootstrap用的比较频繁,发现bootstrap除了框架本身的样式组件外,还提供了多种插...

4624
来自专栏jouypub

优化Vue项目的文件大小

在使用Vue搭建项目时,经常由于引入的库太多,导致打包后的文件体积非常大,特别是vendor.js。这就造成页面第一次打开很慢,如果在浏览器中调试页面(打开控制...

2523
来自专栏九彩拼盘的叨叨叨

CSS拓展语言:Sass介绍

CSS拓展语言出现的原因是,CSS自身支持的功能能有限(如不支持变量,条件控制,循环等编程元素),并不满足我们想要的一些功能。而CSS拓展语言支持CSS不支持的...

1022
来自专栏柠檬先生

Angularjs基础(一)

(一) 模型——视图——控制器     端对端的解决方案,AngularJS 试图成为WEB 应用中的一种段对端的解决方案。AngylarJS 的出众  ...

20710
来自专栏大前端_Web

javascript运行机制:并发模型 与Event Loop

版权声明:本文为吴孔云博客原创文章,转载请注明出处并带上链接,谢谢。 https://blog.csdn.net/wkyseo/articl...

2331
来自专栏优启梦

WordPress 如何判断一篇文章是否存在

一直以来子凡都计划为泪雪网添加一个文章的收藏功能,直到现在也依旧也还只是在计划中,最近几天子凡在研究微信小程序,试图折腾用守望轩开源的WordPress微信小程...

40310
来自专栏java沉淀

Maven、Webx、Velocity学习总结

1483

扫码关注云+社区

领取腾讯云代金券