node.js

Mongoose中_id类型导致的bug

最近使用Mongoose进行数据库连接。使用postman进行测试非法的id长度时报了如下错误。

image 33

刚开始我是不明白这个报的是什么错,经过查找后发现错误在这句代码。

 const user=await User.findById(ctx.params.id);

也就是会把传进来的id在数据库中查询。这个findByid默认就是查询_id字段。而_id是mongoose.Types.ObjectId类型

ObjectId 是一个12字节 BSON 类型数据,有以下格式:

  • 前4个字节表示时间戳
  • 接下来的3个字节是机器标识码
  • 紧接的两个字节由进程id组成(PID)
  • 最后三个字节是随机数。

MongoDB中存储的文档必须有一个”_id”键。这个键的值可以是任何类型的,默认是个ObjectId对象。

在一个集合里面,每个文档都有唯一的”_id”值,来确保集合里面每个文档都能被唯一标识。

_id的长度是24位,上面那个报错是因为长度不正确导致查询的时候无法转化成ObjectId类型。这里加一个长度判断就可以了!

 async checkUserExist(ctx,next){
        if(ctx.params.id.length!=24){
            ctx.throw(404,"没有此用户,id长度不匹配");
        }
        const user=await User.findById(ctx.params.id);//数据库查询必须使用await,否则不等到查询完成就执行下面语句
    
      
        if(!user){
            ctx.throw(404,"没有此用户");
        }
        await next();
    }