首页 > 解决方案 > 使用Speakeasy在nodejs中生成OTP:设置到期时间

问题描述

我正在使用https://www.npmjs.com/package/speakeasy生成 OTP,我希望有效期为 10 分钟。

这是生成的代码

const generateOtp = function generateOtp() {
    let token = speakeasy.totp({
        secret:process.env.OTP_KEY,
        encoding: 'base32',
        digits:4,
        window:10
    });
    return token;
}

验证一次性密码

const verifyOtp = function verifyOtp(token){
    let expiry =  speakeasy.totp.verify({
        secret:process.env.OTP_KEY,
        encoding: 'base32',
        token: token,
        window:10
    });
    console.log(expiry)
}

但我不知道如何将到期时间设置为 10 分钟?

标签: javascriptnode.jsexpressspeakeasy

解决方案


阅读文档你会发现 basestep是 30 秒,所以如果你想有 10 分钟的过期时间,你需要设置stepto 60。然后,使用该verifyDelta方法您应该能够检查令牌是否过期。

const generateOtp = function generateOtp() {
    let token = speakeasy.totp({
        secret:process.env.OTP_KEY,
        encoding: 'base32',
        digits:4,
        step: 60,
        window:10
    });
    return token;
}

const verifyOtp = function verifyOtp(token){
    let expiry =  speakeasy.totp.verifyDelta({
        secret:process.env.OTP_KEY,
        encoding: 'base32',
        token: token,
        step: 60,
        window:10
    });
    console.log(expiry)
}

推荐阅读