添加角色时(使用 asp.net 的角色提供程序),我找不到添加角色的方法,包括描述。
SQL 中的 asp.net 角色表提供了角色描述,但唯一可用的方法是:
Roles.CreateRole(string RoleName);
包含描述没有重载。
是否有一种开箱即用的方式来包含描述?还是我应该自己解决这个问题?
添加角色时(使用 asp.net 的角色提供程序),我找不到添加角色的方法,包括描述。
SQL 中的 asp.net 角色表提供了角色描述,但唯一可用的方法是:
Roles.CreateRole(string RoleName);
包含描述没有重载。
是否有一种开箱即用的方式来包含描述?还是我应该自己解决这个问题?
正如您现在可能发现的那样,没有直接的方法可以获取描述。它之所以存在,是因为它是 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'