C# AmbiguousMatchException 时 GetProperty 并尝试将两个对象相互映射



>我正在尝试创建一个将eUsers list对象映射到用户列表对象的函数。它实际上会映射一些属性,但是当propertyInfo.Name == "UserName"时,它会在以下行上抛出一个AmbiguousMatchException

typeof(User)
    .GetProperty(ePropertyInfo.Name, BindingFlags.IgnoreCase | BindingFlags.Instance | BindingFlags.Public | BindingFlags.SetField)
    .SetValue(user, ePropertyInfo.GetValue(currentEUser));

我测试了一下,它似乎是由 GetProperty 方法触发的。我不太确定是什么原因造成的。这是完整的功能:

private List<User> ConvertEUsersToUsers(List<eUser> eUsers)
{
    List<User> users = new List<User>();
    User user = null;
    IList<PropertyInfo> eUserProps = new List<PropertyInfo>(eUsers.FirstOrDefault().GetType().GetProperties());
    IList<PropertyInfo> userProps = typeof(User).GetProperties();
    foreach (eUser currentEUser in eUsers)
    {
        user = new User();
        foreach (PropertyInfo ePropertyInfo in eUserProps)
        {
            foreach (PropertyInfo propertyInfo in userProps)
            {
                if (propertyInfo.Name == ePropertyInfo.Name)
                {
                    if (ePropertyInfo.CanWrite)
                    {
                        typeof(User)
                            .GetProperty(ePropertyInfo.Name, BindingFlags.IgnoreCase | BindingFlags.Instance | BindingFlags.Public | BindingFlags.SetField)
                            .SetValue(user, ePropertyInfo.GetValue(currentEUser));
                    }
                    break;
                }
            }
        }
        users.Add(user);
    }
    return users;
}

编辑:

以下是用户和 eUser 类的一部分:

[Serializable]
[Application(7)]
[Table("Users")]
public partial class User : MembershipUser, IPrincipal, IIdentity, IEntity, IIdNameClass {
    [Column("Name")]
    public new EntityField UserName { get; set; }
}
[Table("Users")]
public class eUser : User
{
    [NotMapped]
    public Boolean selected { get; set; }
    public new UserTypes UserType { get; set; }
    public eUser() : base()
    {
        selected = false;
    }
}

User类上声明UserName时,通过使用 new 关键字,在其中一个基类中隐藏名为 UserName 的属性。这意味着实际上有多个称为UserName的属性:来自其中一个基类的原始属性,以及User中的新属性。这就是导致AmbiguousMatchException的原因。

尝试使用 BindingFlags.DeclaredOnly 标志仅获取在相关类型上声明的属性:User

相关内容

  • 没有找到相关文章

最新更新