[英]InvalidCastException when using Entity Framework
我正在尝试在会话类中保存用户列表,但是执行POST时会收到InvalidCastException
。
这是我的User类:
public class User
{
[Key]
[DataMember]
public String Email { get; set; }
[DataMember]
public String Password { get; set; }
[DataMember]
public Boolean Admin { get; set; }
public User(String email, String password, Boolean admin)
{
Email = email;
Password = password;
Admin = admin;
}
}
这是我的对话课:
[DataContract]
public class Conversation
{
[Key]
[DataMember]
public string Key { get; set; }
[DataMember]
public string ConversationName { get; set; }
[DataMember]
public string Administrator { get; set; }
[DataMember]
[ForeignKey("Email")]
public List<User> Members { get; set; }
public Conversation(string key, string name, string admin, List<User> members)
{
Key = key;
ConversationName = name;
Administrator = admin;
Members = members;
}
public Conversation()
{
}
}
这是会话控制器:
POST:
[HttpPost]
public async Task<IHttpActionResult> PostConversation(Conversation convo)
{
if (!ModelState.IsValid)
{
return BadRequest(ModelState);
}
foreach (var user in convo.Members)
{
db.Entry(user).State = EntityState.Unchanged;
}
db.Conversations.Add(convo);
await db.SaveChangesAsync();
return CreatedAtRoute("DefaultApi", new { name = convo.Key }, convo);
}
得到:
[HttpGet]
public IQueryable<Conversation> GetConversations()
{
return db.Conversations;
}
编辑帖子声明:
{
"Key": "123",
"ConversationName": "Test",
"Administrator": "Ken",
"Members": [{"Email": "y@12.com","Password" : "Passw-1", "Admin" : "true"},
{"Email": "y@123.com","Password" : "Passw-1", "Admin" : "false"}]
}
我得到的错误是:
“ ExceptionMessage”:“无法将类型为'System.Collections.Generic.List`1 [AcademicAssistant.Models.User]'的对象转换为类型为'AcademicAssistant.Models.User'。”,
您的模型是错误的。 由于Conversation
和User
之间具有N:N关系,因此需要从Members
之前的会话中删除ForeingKey
属性,并且需要在User类中添加ICollection<Conversation> Conversation
属性,或者根据需要使用FluentApi进一步配置该关系
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.