在输出之前隐藏一些对象字段

本文关键字:对象 字段 隐藏 输出 | 更新日期: 2023-09-27 18:26:59

输出前是否可以隐藏某些字段?

为了简单起见,假设我有UserImage,一个用户可以有多个图像。

用户

public class User
{
    public int Id { get; set; }
    public string Name { get; set; }
    public IEnumerable<Image> Images { get; set; }
}

输出

{
    Id: "1",
    Name: "Steve"
}

现在我想输出有图像和没有图像的User。有可能做这样的事吗?
_db.Users.SingleOrDefault(x => x.Id == id).Except(x => x.Images);

  • 这可以通过添加[JsonIgnore]来实现,但这不是一个选项,因为我想在一些不同的请求中输出Images
  • 这可以通过输出匿名对象来实现,但这不是一个选项
  • 这可以通过创建DTO来实现,但即便如此,我如何才能将属性从模型自动分配给DTO?假设我有30个字段,我不想手动分配它们

在输出之前隐藏一些对象字段

假设我有30个字段,我不想手动分配它们。

Automapper救援!

PM>安装包自动映射

DTO:

public class User
{
    public int Id { get; set; }
    public string Name { get; set; }
    public IEnumerable<Image> Images { get; set; }
}
public class UserInfo
{
    public int Id { get; set; }
    public string Name { get; set; }
}

代码:

Mapper.CreateMap<User, UserInfo>();
var user = new User { Id = 1, Name = "Bob" };
var userInfo = Mapper.Map<User, UserInfo>(user);
return Json(new { userInfo });

我认为这也是一个值得您注意的解决方案:您可以定义一些base classinterface,其中包含您想要的元素,比如:

public class UserBase {
  public int Id {get;set}
  public string Name {get;set;}
}
public class User : UserBase {
  public IEnumerable<Image> Images { get; set; }
}
//or using interface, I think this is better
public class IUserBase {
  int Id {get;set}
  string Name {get;set;}
}
public class User : IUserBase {
  public int Id { get; set; }
  public string Name { get; set; }
  public IEnumerable<Image> Images { get; set; }
}

然后在LINQ查询中,您可以执行以下操作:

var result = users.Select(x=>(IUserBase)x);
foreach(var user in result)
   System.Diagnostics.Debug.Print(user.Id + " : " + user.Name);//There is no `Images` element here except using explicitly cast to User type.