Error: Illegal arguments: undefined string at bcrypt.hashSync

用react写后端的signUp时出现报错undefined string at bcrypt.hashSync,代码如下,报错在生成password时!

复制代码
const bcrypt = require('bcryptjs')
const jwt = require('jsonwebtoken')
const db = require('../config/db.config.js')
const User = db.user
const errorHandler = require('../utils/errorHandler')

module.exports.register = async function(req, res) {
    const candidate = await User.findOne({
        where: {
            username: req.body.username
        }
    })

    if (candidate) {
        res.status(409).json({
            message: 'This login is already taken. Try another.'
        })
    } else {
        const salt = bcrypt.genSaltSync(10)
        const password = req.body.password
        const user = new User({
            name: req.body.name,
            username: req.body.username,
            roles: req.body.roles,
            photoSrc: req.file ? req.file.path: '',
            password: bcrypt.hashSync(password, salt)
        })
        try {
            await user.save()
            res.status(201).json(user)
        } catch(e) {
            errorHandler(res, e)
        }
    }
}

修改方式,在生成salt和password时,使用await,因为本身就是异步运行:

复制代码
const salt = await bcrypt.genSaltSync(10);
const password = await req.body.password;
相关推荐
oil欧哟7 分钟前
Agent 设计与上下文工程- 02 Workflow 设计模式(上)
前端·网络·人工智能
StarkCoder7 分钟前
GetX 状态管理优化:从 GetBuilder 到 Obx 的性能提升实践
前端
小高0078 分钟前
深入理解 package.json:前端项目的 "身份证"
前端·javascript·vue.js
StarkCoder10 分钟前
Flutter ListView 数据变动导致的卡顿与跳动问题:Key 的妙用
前端
lichenyang45312 分钟前
Next.js 学习笔记:从约定式路由到 Tailwind、Image、Font 优雅整合。
前端·javascript·全栈
⑩-12 分钟前
浅学Java-设计模式
java·开发语言·设计模式
杂鱼豆腐人12 分钟前
【自用】CSS查漏补缺
前端·css
攻心的子乐13 分钟前
软考 关于23种设计模式
java·开发语言·设计模式
修罗-zero21 分钟前
vue在获取某一个div的大小,怎么确保div渲染好,内容撑开后才去获取大小
前端·javascript·vue.js
咫尺的梦想00722 分钟前
vue笔记(第一天)
前端·vue.js·笔记