在Mongoose中,.isModified()是一个实例方法,用于检测Schema中的某个路径是否已经被修改过。如果路径被修改过,则.isModified()返回true,否则返回false。
而在进行密码哈希处理时,通常会在Pre(前置)钩子函数中进行,因为只有当密码发生了变化时才需要重新对其进行哈希处理。如果不这么做,那么就会对每次改变进行哈希处理,从而浪费时间和处理能力。
以下是一个示例代码,演示了如何在pre(前置)钩子函数中进行密码哈希处理,并使用.isModified()方法来检测密码是否已被修改:
// 导入所需的模块
const mongoose = require('mongoose');
const bcrypt = require('bcrypt');
// 定义用户Schema
const userSchema = new mongoose.Schema({
username: {type: String, required: true},
password: {type: String, required: true}
});
// 定义pre(前置)钩子函数
userSchema.pre('save', function(next) {
const user = this;
// 如果密码没有修改过,则直接跳过
if (!user.isModified('password')) return next();
// 对密码进行哈希处理
bcrypt.genSalt(10, (err, salt) => {
if (err) return next(err);
bcrypt.hash(user.password, salt, (err, hash) => {
if (err) return next(err);
user.password = hash; // 将哈希值保存回用户对象中
next();
});
});
});
// 创建用户model
const User = mongoose.model('User', userSchema);
在这个示例代码中,我们使用了bcrypt模块对密码进行哈希处理,并在前置钩子函数中对密码进行处理。在处理之前,