微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

基于角色的启用/禁用asp.net中的控件

目前我正在开发一个项目,其中有四个角色的用户可以访问相同的页面(有很多页面,每个页面有近80-90个控件:().

要求是,根据每个角色,用户应该能够查看每个页面中的特定控件(即,一个角色可见的控件不需要对其他角色可见).
它看起来非常简单的功能,我也知道我可以使用后面的代码(例如controlname.visible = false等),但由于有很多页面有许多控件,特定于特定的角色,它变得非常冗长而且可维护性较差的代码.

任何人都可以给我最好的方法,这将是强大的,维护良好的代码.(jQuery,Javascript解决方案也将做..)

解决方法

这是去年点击我心中的一个非常好的问题..这是我提出的,它有点冗长,但我希望这可以帮助..

首先,你必须看看Asp.net中的ControlAdapters.

http://www.asp.net/cssadapters/WhitePaper.aspx

概述:
1.为要根据角色启用和禁用的控件类型创建控件适配器.
2.在asp.net控件上应用一些属性,指定哪些角色可以访问该控件.

在asp.net页面尝试这样的事情

<asp:TextBox ID="TextBox1" runat="server" CRAN="1"></asp:TextBox>

这里CRAN是我的自定义属性,1是可以在页面上访问此控件的roleid.

现在是时候创建一个控制适配器,它将根据角色启用/禁用此控件.

public class TextBoxAdapter:
     System.Web.UI.WebControls.Adapters.WebControlAdapter
    {

        protected override void OnLoad(EventArgs e)
        {
            if (this.Page is ISecurable)
            {
                WebControl tb = this.Control as WebControl;

                string roles = tb.Attributes[Constants.ControlRoleAttributeName];
                bool result = true;
                if (!string.IsNullOrEmpty(roles))
                {
                    result = false;
                    string[] role = roles.Split(',');
                    foreach (string r in role)
                    {
                        if (Roles.IsUserInRole(r))
                        {
                            result = true;
                        }
                    }

                }

                tb.Enabled = result;
                //tb.BackColor = Color.Red;
            }
            base.OnLoad(e);
        }
    }

这是我创建的控件适配器,它将根据角色启用/禁用控件.你可以修改这个显示/隐藏控件.

您必须在.browser文件中的asp.net的App_browser文件夹中注册此控件适配器

<browsers>
  <browser refID="Default">
    <controlAdapters>

     <adapter controlType ="System.Web.UI.WebControls.TextBox" adapterType="MyProject.ControlAdapter.TextBoxAdapter" />
    </controlAdapters>
  </browser>
</browsers>

结论:
您必须仅在元素上应用属性才能显示隐藏它们.我已经为TextBox创建了适配器,您可以尝试创建一些通用适配器,如WebControl / Control.

问候.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐