我具有以下类数据结构:

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组合,每个组合具有多个用户角色。

用户类中的org和suborg可以这样写: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
  }
}


有没有更好的方法可以做到这一点来摆脱循环?还是我做对了?

最佳答案

听起来像您想要的:

string orgValue = ddlOrg.SelectedValue;
string subOrgValue = ddlSubOrg.SelectedValue;
btnSubmitToProd = user.orgs
                      .Any(org => orgValue.StartsWith(org.Org.Trim('%')) &&
                                  subOrgValue.StartsWith(org.SubOrg.Trim('%')) &&
                                  org.type.Contains("Admin"));

09-25 22:12