我们有一组实体,其中包含需要对某些用户匿名的数据字段。我们有一个产品数据库,但只有某些用户才能看到该产品的真实名称。其他用户应该只看到产品名称的“匿名”版本(匿名名称存储在产品表的另一个字段中)
我如何使用Entity Framework轻松解决这个问题。我们有一个mapper框架和一个服务层,我们的第一个方法是为返回产品列表的所有方法绘制最终结果,但我们有点失去了导航属性,我们希望避免复制完整的EF结构作为DTO。
是否有一种在EF中注入基于用户的数据替换的简单方法?
答案 0 :(得分:0)
就个人而言,我会使用一个这样做的抽象层。例如存储库模式。
public virtual TPoco Get(Expression<Func<TPoco, bool>> predicate) {
//This routine would execute the normal find or first as you like...eg
var resultEntity = Context.Set<TPoco>().FirstOrDefault(predicate);
// but before returning.
var anonResult = Blender<poco>(TPoco resultEntity); // this does the anon massaging
return AnonResult;
}