魔方Newlife.Cube权限系统的使用及模版覆盖详解

  • 讲人:大石头
  • 时间:2018-11-14 晚上20:00
  • 地点:钉钉群(组织代码BKMV7685)QQ群:1600800
  • 内容:魔方Newlife.Cube权限系统的使用及模版覆盖详解

准备

源码地址: https://github.com/NewLifeX/NewLife.Cube

演示地址:http://cube.newlifex.com  可以直接注册用户以及选用第三方登录

单点登录:htts://sso.newlifex.com

讲课视频1:https://pan.baidu.com/s/1zEUkG7YXnVdvTLq6dJBhzg

讲课视频2:https://pan.baidu.com/s/10omTlET99DF-4cgG2bObzw

开始

1.初识魔方  魔方后台结构介绍

魔方是一个基于ASP.NET MVC的多角色的权限管理系统,新版本的设计目标是所有页面封装在DLL里边,通过覆盖修改视图,做到极简化的使用

1登录

  其中集成了SSO单点登录及第三方OAuth登录,其中既可以作为OAuth客户端也可以作为OAuth服务端,可以自己内部发布一个sso服务器端,只需要发布cube.dll,xcode.dll,core.dll三个dll的空项目即可

1.1顶部菜单栏

  顶部菜单有栏目点击及用户修改注销等功能

1.2工作台首页

   应用系统:地址可以解决Nginx转发的路径不对的问题

   域名地址:多ip或者Nginx代理的显示

          重启系统功能特别有用(缓存没有更新,配置没有生效,重启后会重新加载,轻量级重启,不用iis整个重启

          程序集列表:可以分析是否缺少第三方组件的引用

         .netcore session不建议使用,所以以后尽量不用session

          内部版本,后边两个字段是编译出来的,编译时间来自于内部版本比如2.4.6805.17968,其中内部版本号6805基于2000年1月1日的天数,后边的17968字段是后边的秒数除以2的一个结果

1.3左侧区域菜单

  菜单是树状的多层菜单,菜单树是内存计算的,1000对以内会整体缓存,因此菜单更新后不一定实时显示,因为有缓存,需要重启一下

2.系统菜单中的4个基本功能

    用户

      记录每个用户,可以对用户信息进行管理,其中清除密码功能比较特别,清除密码后可以任意密码登录,登录密码作为新密码存储在数据库中

    日志

      日志作为系统的安全与审计,是不能修改,添加,删除的.其中包含操作记录,访问统计等

    角色

      系统默认了管理员,游客,普通用户,高级用户等几个角色,其中在第一个默认登录系统的账号会自动替换为管理员角色,admin自动降级为游客,角色与名称可以根据自己的业务进行修改,其中我们支持多角色,一个主角色,多个次要角色,多角色是或的关系,只要有权限都支持.

    菜单

      对系统菜单与业务菜单进行编辑与修改,其中系统菜单里边修改过后一定要勾选上必要,不然会被魔方初始化覆盖,其中可见指的是是否在左侧菜单栏中显示,可以自定义权限

  业务菜单

    系统启动后会自动扫描区域与控制器,将区域作为一级菜单加载到数据库,将控制器作为二级子菜单加载到区域菜单下边,其中菜单名字通过[DisplayName("菜单名称")]来注解

 

 

 3.高级功能

  3.1魔方设置

    基本设置

      对系统的一些基本设置,包括全局调试,日志等级,日志目录,插件服务器设置等

    系统设置

      对系统的名称进行设置,登录页,页面头部的名称,其中开发者模式的开关控制着页面的sql输出,以及高级功能里边的生成Form表单与生成List数据页的视图,启用与否代表整个魔方系统是否启用

    数据中间设置

      xcode中间件设置,其中最重要的反向工程设置,默认为on,这个时候会根据实体文件对数据表进行检测,其中会新增字段,不能删除与修改字段,缓存时间一般是10秒,可以设置默认的备份数据库目录,主要针对sqlite文件数据库

    魔方设置

      显示时间控制,作为整个页面的数据库查询时间的一个辅助开发功能设置

      插件服务器设置,这个是所有的插件以及资源服务器的一个设置

      工作台页面设置,作为一个后台权限系统登录进来展示的首页

      布局页设置,是整个mvc布局页的一个设置

      密码登录,启用注册,自动注册强行绑定用户设置都是跟用户相关的一些设置

      下拉框选择,其中下拉框开启后样式为bootstrap,页面加载会比较耗时,如果追求极速,可以考虑关闭下拉框选择

      SSL作为https的强制使用

   3.2文件

    在线的文件管理系统,可以直接上传bin文件以及下载sqlite的备份文件下载到本地

   3.3页面右边高级功能

    清空数据表:其中清空表是checkident操作,会把自增ID重新从1开始

    删除全部:删除当前符合查询条件的全部记录

    导出xml与json,按照xml或者json格式导出当前符合查询条件的记录

    导出excel,测试过最多导出过90w的记录

    生成Form表单:生成表单视图模版文件,可以随意修改视图页面

    生成List数据模版,随意修改列表数据页

4.魔方项目引用及使用

  4.1魔方dll的引用

    新建.NET Framework    MVC项目

  

   在新建项目中右键选择管理Nuget包中搜索NewLife.cube然后安装到本项目中,该cube.dll会自动引入XCode.dll与core.dll,其中cube所需的资源包,项目会自动下载到Content目录下边

  

 安装完成后会在目录生成Model.xml与Build.tt文件,其中Model.xml文件是数据库参考文件

数据库模型文件详细说明见图所标识:

 

Index为默认主键索引,其中表名+主键名称会在实体类Biz.cs中自动生成扩展属性

4.2实体的生成

在build.tt文件上右键选择运行自定义工具就会在Model.xml文件中设定的目录下生成实体文件.cs数据文件,biz.cs业务文件,分部类,一个类放在多个文件里边,biz.cs只是在第一次生成,以后不会覆盖生成,.cs每次更新表都会重新生成

4.3魔方的使用区域与控制器

  在项目上右键在弹出菜单中选择添加,在子菜单中点击区域按钮新增区域Areas,即在左侧新建一个一级菜单

  

我新建了一个Test的区域,修改区域的AreaRegistration文件,将继承修改为AreaRegistrationBase,并使用注解[DisplayName("区域名称即一级菜单的名称")]的方式为该菜单的名称

新建控制器继承自EntityController<实体类>,会自动生成一个二级子菜单,通过注解[DisplayName("二级菜单的名称")]

运行得到该实体列表页,要想列表中某些字段不显示,只需要在控制器中的构造方法里边输入ListFields.Remove("列名”)

 public class MyUserController : EntityController<Log>
    {
        public MyUserController() {
            ListFields.Remove(Log._.CreateUserID);
        }
    }

4.4高级按钮生成表单与列表的视图文件

 

生成模版文件后,点击工程的显示所有按钮,然后在对应的控制器的view目录下将模版文件包括在项目中,这个时候可以对模版进行任意覆盖修改,自己可以多修改运行试试效果,特别注意

需要在views下边的webconfig文件中加入 以下的命名空间

   <add namespace="NewLife" />
        <add namespace="NewLife.Cube" />
        <add namespace="NewLife.Reflection" />
        <add namespace="NewLife.Web" />
        <add namespace="XCode" />
        <add namespace="XCode.Membership" />

 

 

5.魔方的精髓 模版覆盖

 5.1模版介绍

  模版分为表单模版Form.cshtml,列表模版List.cshtml,布局模版,每个模版可以分别单独覆盖,可以局部整体覆盖,真正做到任意覆盖,其中最重要的是可以根据优先级顺序进行整体局部覆盖,需要整站覆盖直接修改     Ace_Layout.cshtml

    其中优先级顺序依次为项目Views-->控制器Views-->Areas Views-->魔方内置Views

    列表模版详细说明如下:整个模版分为_List_Toolbar.cshtml,_List_Data.cshtml,_List_Pager.cshtml

其中_List_Data.cshtml又包含两部分数据部分:_List_Data_Item.cshtml 与 操作部分:_List_Data_Action.cshtml

  

   _List_Toolbar.cshtml是最复杂的功能其中包含批量操作_List_Toolbar_Batch.cshtml,日期搜索_List_Search.cshtml对应(_DateRange.cshtml)不知为何要这样多一个search的页面,不敢揣摩圣意,关键字查询_List_Toolbar_Search.cshtml,高级按钮功能,_List_Toolbar_Adv.cshtml

 

现在示例一下修改Search的查询:首先在控制器中重载一下Search方法,在实体中实现Search的高级搜索方法

   protected override IEnumerable<UserOnline> Search(Pager p)
        {
            var id = p["id"];//取当前页面的id值
            //p["q"]关键字的值
            return UserOnline.Search(p["q"],p);
        }

最后可以使用自定义工具RazorGenerator将视图文件编译成DLL文件,可以联机搜索安装

当项目Views同时使用cshtml文件与DLL的时候优先使用cshtml文件

神奇黑科技:http://cube.newlifex.com/School/Class/json?q=11&Sort=ID&Desc=True&key=abcdefg

魔方支持json,xml导出数据,其中key为token,q为关键字,sort是排序字段

 

posted @ 2018-11-15 18:35  一剑飘红vip  阅读(2110)  评论(3编辑  收藏  举报