在网上查了很多,发现没有讲述关于--C#winform菜单权限分配,与菜单同步的treeView树状菜单权限控制使用--的资料

自己研究了一个使用方法。下面来看看。

我有两个窗体:LOGINFRM,MAINFRM.

首先,说明一点,我的菜单项是通过程序控制动态自动添加到树形控件菜单项的。

第一步,在主窗体MAINFRM中,添加公共变量

        public string username="";//用户名
public string useLOA = "";//权限 public int sa;
//权限
public int userLOA
{
get { return sa; }
set { sa = value; }
}

第二步,在登录窗体中,

            UserName = txtUserName.Text.Trim();//获取用户名
PassWrd = txtPasWrd.Text.Trim();//获取密码
LOA1 = comboBox1.Text;//获取combox1的选项:用户身份获取 。。。。 Form_Main HomePage = new Form_Main();
if (LOA1 == "管理员")//传递权限
{
HomePage.userLOA = ;
}
else//普通用户
{
HomePage.userLOA = ;
}
HomePage.username = UserName; //传递用户名 ,用于状态栏显示
HomePage.useLOA = LOA1;//传递权限,用于状态栏显示
this.Hide();//隐藏登录窗口
//HomePage.StartPosition = FormStartPosition.CenterScreen;//屏幕中央显示窗体
HomePage.Show();//显示主窗口

第三部  在加载主窗体事件中添加

private void Form_Main_Load(object sender, EventArgs e)//窗体加载事件
{
GetMenu(treeView1,menuStrip1);//菜单项添加到树形控件 //MessageBox.Show(userLOA.ToString());//TEST-OK if (userLOA == )//权限限制
{
Excel导入.Enabled = false;
Excel导出.Enabled = false;
添加用户.Enabled = false;
修改密码.Enabled = false;
删除用户.Enabled = false;
}
toolStripStatusLabel2.Text = "当前用户:"+username+", 权限:"+useLOA+"";//状态栏显示用户名和权限
}

第四步,树形菜单权限控制

 
  //TreeView树状菜单和ToolMenuStrip菜单调用的是相同的窗体,下面通过判断

             //ToolMenuStrip菜单项的状态来决定是否打开对应窗体,经过实践证明,下面的方法是有效的。做到了
//TreeView树状菜单权限控制 //水文信息添加
if (FrmName == "Excel导入")
{
//根据菜单状态控制树型菜单项的状态 if (Excel导入.Enabled == false)
{
MessageBox.Show("当前用户无权使用该功能!"); }
else
{
添加frm tianjiafrm = new 添加frm();
tianjiafrm.StartPosition = FormStartPosition.CenterParent;
tianjiafrm.ShowDialog();
tianjiafrm.Dispose();//模态对话框显示
} }
if (FrmName == "Excel导出")
{
if (Excel导出.Enabled==false)
{
MessageBox.Show("当前用户无权使用该功能!");
}
else
{
导出frm daochufrm = new 导出frm();
daochufrm.StartPosition = FormStartPosition.CenterParent;
daochufrm.ShowDialog();
daochufrm.Dispose();//模态对话框显示
} } //系统管理
if (FrmName == "添加用户")
{
if (添加用户.Enabled==false)
{
MessageBox.Show("当前用户无权使用该功能!");
}
else
{
添加用户frm tianjiafrm = new 添加用户frm();
tianjiafrm.StartPosition = FormStartPosition.CenterParent;
tianjiafrm.ShowDialog();
tianjiafrm.Dispose();
} }
if (FrmName == "修改密码")
{
if (修改密码.Enabled==false)
{
MessageBox.Show("当前用户无权使用该功能!");
}
else
{
修改用户信息frm xiugaifrm = new 修改用户信息frm();
xiugaifrm.StartPosition = FormStartPosition.CenterParent;
xiugaifrm.ShowDialog();
xiugaifrm.Dispose();
} }
if (FrmName == "删除用户")
{
if (删除用户.Enabled==false)
{
MessageBox.Show("当前用户无权使用该功能!");
}
else
{
删除用户frm sanchufrm = new 删除用户frm();
sanchufrm.StartPosition = FormStartPosition.CenterParent;
sanchufrm.ShowDialog();
sanchufrm.Dispose(); } }
if (FrmName=="使用说明")
{ 使用说明frm usertip = new 使用说明frm();
usertip.StartPosition = FormStartPosition.CenterParent;
usertip.ShowDialog();
usertip.Dispose();
}
if (FrmName=="关于")
{
AboutBox1 aboutfrm = new AboutBox1();
aboutfrm.StartPosition = FormStartPosition.CenterParent;
aboutfrm.ShowDialog();
aboutfrm.Dispose(); }

C#winform菜单权限分配,与菜单同步的treeView树状菜单权限控制使用心得的更多相关文章

  1. 菜鸟笔记:node.js+mysql中将JSON数据构建为树(递归制作树状菜单数据接口)

    初学Web端开发,今天是第一次将所学做随笔记录,肯定存在多处欠妥,望大家海涵:若有不足,望大家批评指正. 进实验室后分配到的第一个项目,需要制作一个不确定层级树形菜单的数据接口,对于从来没实战编过程的 ...

  2. MVC身份验证.MVC过滤器.MVC6关键字Task,Async.前端模拟表单验证,提交.自定义匿名集合.Edge导出到Excel.BootstrapTree树状菜单的全选和反选.bootstrap可搜索可多选可全选下拉框

    1.MVC身份验证. 有两种方式.一个是传统的所有控制器继承自定义Control,然后再里面用MVC的过滤器拦截.所以每次网站的后台被访问时.就会先走入拦截器.进行前端和后端的验证 一个是利用(MVC ...

  3. 纯CSS打造可折叠树状菜单

    1:Html代码 <li> <label for="subsubfolder1">下级</label> <input id="s ...

  4. 自写JQ控件-树状菜单控件[demo下载]

    一个多月没有写博客了,最近也弄一个基于JQ的树状菜单控件,在此分享给大家.另外呢,通过这个例子分享一下怎么写JQ控件的. 事实上工作中,也是经常遇到的,有些时候自己想实现一些前端效果,用网上一些插件吧 ...

  5. 学用纯CSS打造可折叠树状菜单

    随着CSS3的发布,国外研究正如火如荼,但在国内还有很多人抱着IE不支持CSS3的想法,始终无动于衷不肯去学习.但是历史告诉我们,好的东西必将盛行,CSS3也终将也会替代CSS2,下面就和大家分享一个 ...

  6. js, 树状菜单隐藏显示

    js写的不是很严谨~~~嘿嘿   <!DOCTYPE html> <html> <head> <meta charset="UTF-8"& ...

  7. mysql用户权限分配及主从同步复制

    赋予wgdp用户查询权限: grant select on wg_dp.* to 'wgdp'@'%' IDENTIFIED BY 'weigou123'; grant all privileges ...

  8. 后台树状菜单,js实现递归无限分类

    //新闻类别管理 public function new_classify() { $arr = M('news_classify')->where("fid = 0")-& ...

  9. GUI自绘_其中左边树状菜单控件风格灵感来源于城市博物馆的壁灯效果。

    GUI DEMO 下面都是去年做的演示DEMO,到目前为止,除了专门做界面库的公司,暂时还没有看到别人做的效果比我这个更好的. 下图在第一张图中有个错误,看出来了没有呢? 就是项目核算那儿,不应该是B ...

随机推荐

  1. redis nginx session tomcat

    Redis解决session共享 http://lyl-zsu.iteye.com/blog/2408292 http://zx10103326.iteye.com/blog/2244195 http ...

  2. diff详解,读懂diff结果-转载

    阅读目录 1.概述 2.diff如何工作,如何理解diff的执行结果 3.Normal模式 4.Context模式 5.Unified模式 6.比较目录 7.一些有用的参数 回到顶部 1.概述 本文将 ...

  3. 安装cartographer_ros

    这里使用的是hitcm(张明明)的github地址,由于google官方的教程需要FQ下载一些文件,因此容易失败,经验证hitcm(张明明)对原文件进行了少许修改后可以成功安装,在他的修改中核心代码不 ...

  4. CASSANDRA How to import and export data

    https://docs.datastax.com/en/cql/3.1/cql/cql_reference/copy_r.html 感谢领导,感谢同事,与其自己百思不得其解,不如一个问题就搞定了. ...

  5. 30分钟了解Shiro与Springboot的多Realm基础配置

    写在前面的话: 我之前写过两篇与shiro安全框架有关的博文,居然能够广受欢迎实在令人意外.说明大家在互联网时代大伙对于安全和登录都非常重视,无论是大型项目还是中小型业务,普遍都至少需要登录与认证的逻 ...

  6. Vue项目骨架屏注入实践

    相比于早些年前后端代码紧密耦合.后端工程师还得写前端代码的时代,如今已发展到前后端分离,这种开发方式大大提升了前后端项目的可维护性与开发效率,让前后端工程师关注于自己的主业.然而在带来便利的同时,也带 ...

  7. mac 下安装mongodb

    转载自https://segmentfault.com/a/1190000002547229 概念 MongoDB 是一个跨平台的,面向文档的数据库,提供高性能,高可用性和可扩展性方便. MongoD ...

  8. Java-Java程序设计的基本概念

    2017-10-06 15:31:39 一.Java程序的基本构成             二.数据类型与标识符 数据类型 标识符 广义的用于定义各种对象名称的字符串集合称为标识符,标识符一般分为用户 ...

  9. 20170706xlVBA城中村改造汇总

    Public Sub GatherDataPicker() Application.ScreenUpdating = False Application.DisplayAlerts = False A ...

  10. tomcat8w.exe 运行 提示 指定的服务未安装 unable to open the service 'tomcat8'

    新下载的Tomcat8 解压版,解压缩完成后,双击tomcat8.exe出现个DOS样子的窗口一闪而过消失了,tomcat也没有启动成功.双击tomcat8w.exe 弹出个错误对话框,说“指定的服务 ...