我有以下类数据结构:
public class clsUser
{
public string userid { get; set; }
public List<OrgPermission> orgs { get; set; }
}
public class OrgPermission
{
public string Org { get; set; }
public string SubOrg {get;set;}
public List<string> type { get; set; }
}
List<string> type
可以有诸如“admin”、“user”、“superuser”等值。
因此每个用户可以拥有多个 org-suborg 组合,每个组合具有多个用户角色。
用户类中的 orgs 和 suborgs 可以这样写:56%(这意味着他们可以看到以 56 开头的所有内容)
我想检查用户是否有权访问“管理员”类型页面上的 org-suborg 组合
现在我正在用一个循环来做这件事,它的工作原理是这样的:
foreach (OrgPermission userOrg in user.orgs) {
if ((ddlOrg.SelectedValue.StartsWith(userOrg.Org.Trim('%'))) && (ddlSubOrg.SelectedValue.StartsWith(userOrg.SubOrg.Trim('%')))) {
if (userOrg.type.Contains("Admin"))
btnSubmitToProd.Enabled = true;
else
btnSubmitToProd.Enabled = false;
break; //break out of the loop if the org-sub org match is found
}
}
有没有更好的方法来摆脱循环?还是我做对了?