热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

解析猫鼬findOne方法返回null的原因

本文探讨了在通过API端点调用时,使用猫鼬(Mongoose)的findOne方法总是返回null的问题,并提供了详细的解决方案和建议。

当您通过 Postman 或其他工具调用 API 端点时,可能会遇到猫鼬 findOne 方法返回 null 的情况。以下是具体代码示例及其解释:

exports.updateUserPassword = async (req, res) => {
const user = await User.findOne({
resetPasswordExpires: { $gt: Date.now() },
resetPasswordToken: req.params.token
});
if (!user) {
return res.json({ msg: '密码无效或已过期' });
}
}

在终端上打印出的日志如下所示:

{
_id: 5e4553309d0e232a60gc8b6a,
username: 'Dan_rey',
userType: 'Group',
email: 'dan123@gmail.com',
password: '$2b$10$lq6BYYckKkOtY.as.EILMe7a.njPyBrHauxMlFfianxmSwdmiAT12',
date: 2019-12-29T19:49:04.608Z,
__v: 0,
resetPasswordExpires: 2019-12-30T19:04:05.874Z,
resetPasswordToken: '65bc534656b321907c5af968b13d0a44f41de73b'
}

您希望只查询 resetPasswordExpiresresetPasswordToken 字段。

问题可能源于 Date.now() 返回的时间戳格式与存储在数据库中的日期格式不匹配。MongoDB 中存储的日期通常是 ISO 格式的日期对象,而 Date.now() 返回的是纪元时间戳(毫秒)。为了确保查询条件正确,应使用 new Date() 替代 Date.now()

例如:

const user = await User.findOne({
resetPasswordExpires: { $gt: new Date() },
resetPasswordToken: req.params.token
});

为了验证这一点,您可以插入以下文档到 MongoDB 中进行测试:

{
"_id": ObjectId("5e4553309d0e232a60gc8b6a"),
"username": "Dan_rey",
"userType": "Group",
"email": "dan123@gmail.com",
"password": "$2b$10$lq6BYYckKkOtY.as.EILMe7a.njPyBrHauxMlFfianxmSwdmiAT12",
"date": ISODate("2019-12-29T19:49:04.608Z"),
"__v": 0,
"resetPasswordExpires": ISODate("2019-12-30T19:04:05.874Z"),
"resetPasswordToken": "65bc534656b321907c5af968b13d0a44f41de73b"
}

有关更多信息,请参考:MongoDB 官方文档


推荐阅读
  • 本文介绍了如何在 Node.js 中使用 `setDefaultEncoding` 方法为可写流设置默认编码,并提供了详细的语法说明和示例代码。 ... [详细]
  • 本文探讨了如何使用pg-promise库在PostgreSQL中高效地批量插入多条记录,包括通过事务和单一查询两种方法。 ... [详细]
  • 利用 Jest 和 Supertest 实现接口测试的全面指南
    本文深入探讨了如何使用 Jest 和 Supertest 进行接口测试,通过实际案例详细解析了测试环境的搭建、测试用例的编写以及异步测试的处理方法。 ... [详细]
  • XNA 3.0 游戏编程:从 XML 文件加载数据
    本文介绍如何在 XNA 3.0 游戏项目中从 XML 文件加载数据。我们将探讨如何将 XML 数据序列化为二进制文件,并通过内容管道加载到游戏中。此外,还会涉及自定义类型读取器和写入器的实现。 ... [详细]
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • 本文详细介绍了 Apache Jena 库中的 Txn.executeWrite 方法,通过多个实际代码示例展示了其在不同场景下的应用,帮助开发者更好地理解和使用该方法。 ... [详细]
  • 本文详细探讨了VxWorks操作系统中双向链表和环形缓冲区的实现原理及使用方法,通过具体示例代码加深理解。 ... [详细]
  • 本文介绍如何使用JPA Criteria API创建带有多个可选参数的动态查询方法。当某些参数为空时,这些参数不会影响最终查询结果。 ... [详细]
  • MySQL索引详解与优化
    本文深入探讨了MySQL中的索引机制,包括索引的基本概念、优势与劣势、分类及其实现原理,并详细介绍了索引的使用场景和优化技巧。通过具体示例,帮助读者更好地理解和应用索引以提升数据库性能。 ... [详细]
  • 本文详细介绍了如何在 Windows 环境下使用 node-gyp 工具进行 Node.js 本地扩展的编译和配置,涵盖从环境搭建到代码实现的全过程。 ... [详细]
  • 在 Flutter 开发过程中,开发者经常会遇到 Widget 构造函数中的可选参数 Key。对于初学者来说,理解 Key 的作用和使用场景可能是一个挑战。本文将详细探讨 Key 的概念及其应用场景,并通过实例帮助你更好地掌握这一重要工具。 ... [详细]
  • 本文探讨了Web开发与游戏开发之间的主要区别,旨在帮助开发者更好地理解两种开发领域的特性和需求。文章基于作者的实际经验和网络资料整理而成。 ... [详细]
  • 本文详细介绍了 Node.js 中 Worker.isMainThread 属性的功能、用法及其实例代码,帮助开发者更好地理解和利用多线程技术。 ... [详细]
  • Node.js 中 GET 和 POST 请求的数据处理
    本文详细介绍了如何在 Node.js 中使用 GET 和 POST 方法来处理客户端发送的数据。通过示例代码展示了如何解析 URL 参数和表单数据,并提供了完整的实现步骤。 ... [详细]
  • 本文深入探讨了 Prototype.js 框架及其与 JavaScript 原生 toString() 方法之间的区别,适合对前端开发感兴趣的开发者阅读。文章将帮助读者理解两者在功能实现和应用场景上的不同,从而更好地利用这些工具进行高效编程。 ... [详细]
author-avatar
安静哒发呆
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有