承接 lizhijun/php-totp 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

lizhijun/php-totp

最新稳定版本:1.0.1

Composer 安装命令:

composer require lizhijun/php-totp

包简介

基于时间的一次一密(Time-based One-time Password, TOTP)算法php函数库

README 文档

README

Tests

TOTP(Time-based One-Time Password),基于时间同步,主要通过一个时间因素来实现验证,它的生成依靠当前时间点与基准时间(如UNIX时间戳)的算法,从而生成出一个唯一的密码。

安装

composer -vvv require lizhijun/php-totp

调用

生成 TOTP 密钥 和 二维码字符串

use Lizhijun\TOTP\TOTPAuth;

public function generateTOTP(){
    $auth = new TOTPAuth();
    $secret = $auth->createSecret();
    $qrcodeStr = $auth->getQrcodeStr($secret, 'zhansan', 'org');
    
    // todo: qrcode提供前端生成二维码
}

验证 TOTP密钥

use Lizhijun\TOTP\TOTPAuth;

public function bindTOTP(){

    $secret = ''; // 上一步生成的 TOTP 密钥
    $code = '';   // 用户使用二次密码验证器扫码后,验证器生成`一次性数字验证密码`
    $auth = new TOTPAuth();
    
    $verifyResult = $auth->verifyCode($secret, $code);
    if ($verifyResult) {
        // todo: 验证成功 绑定 TOTP 密钥到用户信息
    } else {
    }
}
  • 用户使用 密码验证器 扫码后,验证器生成一次性数字验证密码
  • 服务端验证用户 一次性数字验证密码TOTP 密钥
  • 生成密钥可持久化到关联用户表

验证器推荐

应用市场搜索并安装以下任一验证器:

  • 谷歌身份验证器 (Google Authenticator)
  • 微软身份验证器 (Microsoft Authenticator)

参考

统计信息

  • 总下载量: 20
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 2
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 1
  • Watchers: 1
  • Forks: 1
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2023-11-23