位置: 编程技术 - 正文

php集成动态口令认证(php动态语言)

编辑:rootadmin

推荐整理分享php集成动态口令认证(php动态语言),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:php动态函数,php动态函数,php动态语言,php集成动态口令是什么,php动态语言,php集成动态口令怎么用,php集成动态口令怎么用,php集成动态口令怎么用,内容如对您有帮助,希望把文章链接给更多的朋友!

大多数系统目前均使用的静态密码进行身份认证登录,但由于静态密码容易被窃取,其安全性无法满足安全要求。

动态口令采用一次一密、用过密码作废的方式防止了密码被窃取带来的安全问题。 动态口令分为HOTP(基于事件计数的动态口令,RFC)、TOTP(基于时间计数的动态口令,RFC)、OCRA(挑战应答式动态口令,RFC)等方式。

本文介绍了集成TOTP方式的动态口令认证的方案,PHP框架采用Thinkphp3.2.3,动态口令生成器使用的是google authtication。

1、为Thinkphp框架添加oath算法类

oath算法封装类oath.php代码如下:

由于google的动态口令算法中种子密钥使用了base编码,因此需要base算法,base.php内容如下:

将这两个文件放到Thinkphp框架的ThinkPHPLibraryVendoroath目录下,oath目录是自己创建的。

2、添加数据库字段

用户表添加如下字段: auth_type(0-静态密码,1-动态口令) seed(种子密钥) temp_seed(临时种子密钥) last_logintime(上次登录成功时间) last_otp(上次使用密码) 其中auth_type是为了标明用户使用的哪种认证方式,seed为用户的种子密钥,temp_seed为用户未开通前临时保存的一个种子密钥,如果用户开通动态口令认证成功,该字段内容会填到seed字段。last_logintime和last_otp为上次认证成功的时间和动态口令,用于避免用户同一个口令重复使用。

3、代码集成

php集成动态口令认证(php动态语言)

1)、开通动态口令

在原有系统的修改密码页面,加上认证方式的选择,例如:

如果用户选择动态口令方式,则会生成一张二维码显示在页面,用于用户开通动态口令。为了兼容google authtication,其二维码格式与谷歌一样。生成二维码的方法见我的另一篇《Thinkphp3.2.3整合phpqrcode生成带logo的二维码》 。 生成密钥二维码代码如下:

random是生成随机字符串函数。$rand=str_replace('=','',$rand)这句代码是因为谷歌手机令牌中base解码算法并没有填充的‘='号。

验证用户动态口令的代码如下:

2)、动态口令登录

用户动态口令登录验证的代码:

从数据库读取auth_type,seed,last_otp字段。

4、测试验证

下载google authtication,使用静态密码登录系统,进入修改密码页面。 打开google authtication,扫描二维码,会显示动态口令。

保存内容,开通动态口令成功! 然后你就可以用高大上的动态口令登录系统了!

标签: php动态语言

本文链接地址:https://www.jiuchutong.com/biancheng/301313.html 转载请保留说明!

上一篇:微信随机生成红包金额算法php版(微信随机红包表情包怎么弄)

下一篇:微信红包随机生成算法php版(微信红包的随机性)

  • 城市维护建设税优惠政策
  • 两个账户往来款怎么做现金流量表
  • 劳务外包可以差额纳税吗
  • 专票没有税点
  • 公司抬头的发票
  • 填写三季度预缴所得税申报表应关注哪些事项
  • 对于子女继承父母的评价
  • 合同印花税申报表怎么填写
  • 小规模纳税人进项发票怎么做账
  • 固定资产盘盈可计入
  • 增值税抵扣进项税额交税账务处理
  • 个体工商户税收标准2023年
  • 营改增一般纳税人申请过渡性财政扶持资金
  • 分期付款融资账务处理
  • 应收票据收到了吗
  • 双系统怎么卸载ubuntu
  • mac打不开网页但是可以上微信
  • 取得其他权益工具投资发生的交易费用
  • 公司为员工购买社保流程
  • 无u刷bios一直闪
  • php自定义变量
  • RPDFLchr.exe - RPDFLchr是什么进程 有什么用
  • win10任务栏变成黑色
  • 在建工程完工后结转会计分录
  • win11怎么创建新用户
  • ios.开发
  • php使用oci8扩展连接oracle
  • 前端框架源码
  • node-gyp版本
  • phpwhile循环多维数组
  • 交易所转交易所手续费是多少
  • 其他收益放在哪里
  • jsp连接数据库的步骤
  • 有留抵税额可以注销吗
  • 房屋租赁税缴纳时间
  • 对公账户转私人账户
  • 赊销应收款余额怎么算
  • 申报无票收入后怎么回冲
  • 跨月普票发票怎么红冲
  • 逾期的押金收入
  • 短期借款按月计提的分录
  • 公司购买的五金怎么入账
  • 留抵税额抵减欠税滞纳金
  • 如何理解出口退税的意义
  • 融资租赁固定资产的账务处理实例
  • 在建工程账务处理问题有哪些
  • 个体工商户个税怎么申报
  • 报关单的运费没填怎么办
  • 不同利益主体之间的利益如何协调
  • 融资手续费计入长期待摊
  • 合同取得成本包括什么
  • 进项税额转出科目编码
  • 如何填写记账凭证视频
  • 远程登陆服务器命令
  • mysql 5.7 8.0
  • mysql5.7.23
  • sql server 更改字段数据类型
  • mac下安装anaconda
  • windows server 2003安装域控制器的方法
  • windows10pc游戏无法全屏
  • 你一定不知道的56个历史真相
  • window10声音自动减小
  • linux中文件系统
  • linux cr3
  • win8怎么查看隐藏文件
  • linux创建.c
  • css制作动画
  • unity3D游戏开发
  • linux shell脚本中sudo后输入密码
  • 局域网远程开机与远程唤醒
  • batfor循环里变量计算
  • 使用express
  • webservice规范
  • android studio报错
  • 如何使用nginx
  • pythonglobal用法
  • androidstudio快速入门
  • 公司开票明细如何查询
  • 社保逾期未申报会造成什么影响,要怎么处理
  • 简述会计估计及其特点
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设