MongoDB元素名称_id无效(更新)

时间:2016-11-28 09:54:12

标签: mongodb exception serialization

我一直在尝试通过mongodb更新用户,每当我运行该方法时,它都会给我一个例外。

MongoDB.Bson.BsonSerializationException: Element name '_id' is not valid'.

我称之为单元测试的方法。

public void TestPutMethod()
    {
        UserEdit userEditSuccess = new UserEdit()
        {
            Password = "newpassword",
            Email = "newemail",
            FirstName = "newfirstname",
            Id = ObjectId.Parse("5828491d63b2a67418591517")
        };

        IHttpActionResult httpActionResult = _controller.Put(userEditSuccess);
        OkNegotiatedContentResult<User> httpActioNResultCast = httpActionResult as OkNegotiatedContentResult<User>;

        Assert.IsInstanceOfType(httpActionResult, typeof(OkNegotiatedContentResult<User>));

    }

单元测试使用看起来像这样的put方法。

[HttpPut]
    public IHttpActionResult Put(UserEdit userEdit)
    {

        if (userEdit.FirstName == null || userEdit.Email == null || userEdit.Password == null)
            return BadRequest("Incorrect input.");
        {
            using (DataContext db = new DataContext())
            {
                User user = new User
                {
                    FirstName = userEdit.FirstName,
                    Email = userEdit.Email
                };

                byte[] password = Encoding.Unicode.GetBytes(userEdit.Password);

                byte[] salted = Password.CreateSalt();
                user.Salt = Encoding.Unicode.GetString(salted);

                byte[] passHash = Password.GernarateSaltedHash(password, salted);
                user.PassHash = Encoding.Unicode.GetString(passHash);
                db.Update("user", i => i.Id == userEdit.Id, user);
                return Ok(user);
            }
        }
    }

抛出异常的方法是看起来像这样的更新方法。

public void Update<T>(string collectionName, Expression<Func<T, bool>> filter, T obj)
    {
        Update(GetCollection<T>(collectionName), filter, obj);
    }

我已经添加了User类和UserEdit类的属性,如下所示。

public class UserEdit
{
    [BsonId, BsonRepresentation(BsonType.ObjectId)]
    public ObjectId Id { get; set; }
    public string FirstName { get; set; }
    public string Email { get; set; }
    public string Password { get; set; }
}

而且这个。

public class User
{
    [BsonId]
    [BsonRepresentation(BsonType.ObjectId)]
    public ObjectId Id { get; set; }
    public string FirstName { get; set; }
    public string Email { get; set; }
    [IgnoreDataMember]
    public string PassHash { get; set; }
    [IgnoreDataMember]
    public string Salt { get; set; }

如果有人知道出了什么问题,或者您需要其他信息,请告诉我。

更新:要求解释GetCollection,它看起来像这样。

_database = client.GetDatabase("campanion");

public IMongoCollection<T> GetCollection<T>(string name)
    {
        return _database.GetCollection<T>(name);
    }

它基本上是从数据库返回一个集合,无论我输入什么名称输入。

2 个答案:

答案 0 :(得分:2)

我刚刚遇到了同样的情况,Michael Kirkegaard是正确的。当您使用ReplaceOne方法时,它将覆盖Json文档。

这正是场景所需要的。否则我相信你必须从对象中删除_id属性。

答案 1 :(得分:0)

它正在尝试访问更新定义对象的Id属性,该属性应具有用于更新文档的特定属性的运算符。

类似:

var updateDefinition = new BsonDocument("$set", new BsonDocument("FirstName", "newfirstname"));

如果要更新完整文档,请使用ReplaceOne。