最近使用Mongoose进行数据库连接。使用postman进行测试非法的id长度时报了如下错误。
刚开始我是不明白这个报的是什么错,经过查找后发现错误在这句代码。
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();
}