2

添加角色时(使用 asp.net 的角色提供程序),我找不到添加角色的方法,包括描述。

SQL 中的 asp.net 角色表提供了角色描述,但唯一可用的方法是:

Roles.CreateRole(string RoleName);

包含描述没有重载。

是否有一种开箱即用的方式来包含描述?还是我应该自己解决这个问题?

4

1 回答 1

4

正如您现在可能发现的那样,没有直接的方法可以获取描述。它之所以存在,是因为它是 BaseProvider 的成员。现在,制作自己的方法来添加对描述的支持非常简单。虽然您不能扩展 Roles 类,但您可以执行以下操作:

public static class RolesEx
{
  public static void CreateRole(string roleName, string description)  
  {  
    Roles.CreateRole(roleName);

    var c = new SqlConnection("connString");  
    var cmd = c.CreateCommand();
    cmd.CommandText =
      string.Format(
        "UPDATE aspnet_Roles SET Description = '{0}' WHERE ApplicationId = (SELECT ApplicationId FROM aspnet_Applications WHERE LoweredApplicationName = '{1}') AND  LoweredRoleName = '{2}'",
        description, Roles.ApplicationName.ToLower(), roleName.ToLower());
    cmd.CommandType = CommandType.Text;
    c.Open();
    var i = cmd.ExecuteNonQuery();
    c.Close();
  }
}

如果代码看起来很乱,我很抱歉。这是我在这里的第一篇文章oO'

于 2010-12-10T14:05:56.810 回答