Я пытаюсь использовать EF с Code First и Web API. У меня нет никаких проблем, пока я не перейду к сериализации отношений "многие-ко-многим". Когда я пытаюсь выполнить следующий метод web api ниже, я получаю следующее сообщение об ошибке:
public class TagsController : ApiController
{
private BlogDataContext db = new BlogDataContext();
// GET api/Tags
public IEnumerable<Tag> GetTags()
{
return db.Tags.AsEnumerable();
}
}
Я получаю следующую ошибку:
'System.Data.Entity.DynamicProxies.Tag_FF17EDDE6893000F7672649A39962DB0CA591C699DDB73E8C2A56203ED7C7B6D' с именем контракта с данными 'Tag_FF17EDDE6893000F7672649A39962DB0CA591C699DDB73E8C2A56203ED7C7B6D: http://schemas.datacontract.org/2004/07/System.Data.Entity.DynamicProxies' не ожидается. Рассмотрите возможность использования DataContractResolver или добавьте типы, неизвестные статически списку известных типов - например, используя атрибут KnownTypeAttribute или добавив их в список известных типов, переданных в DataContractSerializer.
Я прочитал некоторые статьи SO (статья 1, статья 2), что исправление заключается в добавлении следующий атрибут:
[DataContract (IsReference = true)]
но это не повлияло. Также использование [IgnoreDataMember] не имеет эффекта. Единственный вариант, который, похоже, работает, - установить для параметра Configuration.ProxyCreationEnabled значение false. Это мой единственный вариант? Я что-то пропустил?
Примеры объектов POCO:
Тег
[DataContract(IsReference = true)]
public class Tag
{
public Tag()
{
this.Blogs = new HashSet<Blog>();
}
[Key]
[DataMember]
public int Id { get; set; }
[DataMember]
public string Name { get; set; }
[IgnoreDataMember]
public virtual ICollection<Blog> Blogs { get; set; }
}
Блог
[DataContract(IsReference = true)]
public class Blog
{
public Blog()
{
this.Tags = new HashSet<Tag>();
}
[Key]
[DataMember]
public int Id { get; set; }
[DataMember]
public string Name { get; set; }
[IgnoreDataMember]
public virtual ICollection<Tag> Tags { get; set; }
}