我将我的Entity Framework实体从Web项目和数据访问层中拆分出来,放在单独的类库中。在我的控制器中,我调用我的存储库来获取一个IEnumerable<RobotDog.Entities.Movie>
,然后尝试使用JavaScriptSerializer
序列化为JSON,但是我收到了循环引用的错误,即使我使用了[ScriptIgnore]
属性。
重要提示:最初,我的实体、数据访问和Web都在一个项目中,我成功地序列化了我的实体而没有循环引用。当我创建了单独的层时,问题就出现了。我没有更改任何实体。
一个位于RobotDog.Entities
命名空间中的实体示例:
namespace RobotDog.Entities {
public class Character {
[Key]
[DatabaseGenerated(DatabaseGeneratedOption.Identity)]
public int Id { get; set; }
[MaxLength(200)]
public string Name { get; set; }
public virtual Person Person { get; set; }
[ScriptIgnore]
public virtual Movie Movie { get; set; }
}
}
我的控制器:
namespace RobotDog.Web.Controllers {
public class MoviesController : Controller {
private UnitOfWork _unitOfWork = new UnitOfWork();
[HttpGet]
public ActionResult Index() {
var user = Membership.GetUser(User.Identity.Name);
if(user != null) {
var movies = _unitOfWork.UserMovieRepository.Get(u => u.UserId == (Guid) user.ProviderUserKey).Select(m => m.Movie);
var serializer = new JavaScriptSerializer();
var json = serializer.Serialize(movies);
return View(json);
}
return View();
}
}
}
我的代码库:
namespace RobotDog.DataAccess.Movies {
public class Repository<TEntity> : IRepository<TEntity> where TEntity : class {
internal MovieContext Context;
internal DbSet<TEntity> DbSet;
public Repository(MovieContext context) {
if (context == null)
throw new ArgumentNullException("context");
Context = context;
DbSet = Context.Set<TEntity>();
}
public virtual IEnumerable<TEntity> Get(Expression<Func<TEntity, bool>> predicate = null, Func<IQueryable<TEntity>, IOrderedQueryable<TEntity>> orderBy = null ) {
IQueryable<TEntity> query = DbSet;
if (predicate != null)
query = query.Where(predicate);
return orderBy != null ? orderBy(query).ToList() : query.ToList();
}
}
}
JsonConvert
,但我不喜欢在本应该工作的情况下需要编写更多代码的想法。最初,通过使用[ScriptIgnore]
修饰属性,它可以在将其分成多个项目之前正常工作。我还研究了创建viewModel,然后使用AutoMapper将两种类型映射起来。但我无法理解为什么要编写更多代码才能完成不需要代码完成的任务。此外,无法弄清楚为什么这不起作用正在让我发疯 :) - bflemi3